2013-03-23 23:46:20 +01:00
|
|
|
/*
|
|
|
|
|
|
|
|
Copyright 2010, Google Inc.
|
|
|
|
All rights reserved.
|
|
|
|
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
|
|
modification, are permitted provided that the following conditions are
|
|
|
|
met:
|
|
|
|
|
|
|
|
* Redistributions of source code must retain the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer.
|
|
|
|
* Redistributions in binary form must reproduce the above
|
|
|
|
copyright notice, this list of conditions and the following disclaimer
|
|
|
|
in the documentation and/or other materials provided with the
|
|
|
|
distribution.
|
|
|
|
* Neither the name of Google Inc. nor the names of its
|
|
|
|
contributors may be used to endorse or promote products derived from
|
|
|
|
this software without specific prior written permission.
|
|
|
|
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
|
|
OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
|
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
2019-08-23 12:55:31 +02:00
|
|
|
package com.google.refine;
|
2013-03-23 23:46:20 +01:00
|
|
|
|
|
|
|
import static org.mockito.Mockito.mock;
|
|
|
|
import static org.mockito.Mockito.never;
|
|
|
|
import static org.mockito.Mockito.spy;
|
|
|
|
import static org.mockito.Mockito.times;
|
|
|
|
import static org.mockito.Mockito.verify;
|
|
|
|
import static org.mockito.Mockito.verifyNoMoreInteractions;
|
|
|
|
import static org.mockito.Mockito.when;
|
|
|
|
|
2017-12-15 21:24:09 +01:00
|
|
|
import java.time.LocalDateTime;
|
2013-03-23 23:46:20 +01:00
|
|
|
|
|
|
|
import org.mockito.Mockito;
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
import org.testng.Assert;
|
|
|
|
import org.testng.annotations.AfterMethod;
|
|
|
|
import org.testng.annotations.BeforeMethod;
|
|
|
|
import org.testng.annotations.BeforeTest;
|
|
|
|
import org.testng.annotations.Test;
|
|
|
|
|
2018-11-17 21:42:34 +01:00
|
|
|
import com.google.refine.ProjectMetadata;
|
2013-03-23 23:46:20 +01:00
|
|
|
import com.google.refine.model.Project;
|
2019-08-23 12:55:31 +02:00
|
|
|
import com.google.refine.model.ProjectStub;
|
2013-03-23 23:46:20 +01:00
|
|
|
import com.google.refine.process.ProcessManager;
|
|
|
|
|
|
|
|
public class ProjectManagerTests extends RefineTest {
|
|
|
|
ProjectManagerStub pm;
|
|
|
|
ProjectManagerStub SUT;
|
|
|
|
Project project;
|
|
|
|
ProjectMetadata metadata;
|
|
|
|
ProcessManager procmgr;
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@BeforeTest
|
|
|
|
public void init() {
|
|
|
|
logger = LoggerFactory.getLogger(this.getClass());
|
|
|
|
}
|
|
|
|
|
|
|
|
@BeforeMethod
|
|
|
|
public void SetUp(){
|
|
|
|
pm = new ProjectManagerStub();
|
|
|
|
SUT = spy(pm);
|
|
|
|
project = mock(Project.class);
|
|
|
|
metadata = mock(ProjectMetadata.class);
|
|
|
|
procmgr = mock(ProcessManager.class);
|
|
|
|
when(project.getProcessManager()).thenReturn(procmgr);
|
|
|
|
when(procmgr.hasPending()).thenReturn(false); // always false for now, but should test separately
|
|
|
|
}
|
|
|
|
|
|
|
|
@AfterMethod
|
|
|
|
public void TearDown(){
|
|
|
|
metadata = null;
|
|
|
|
project = null;
|
|
|
|
SUT = null;
|
|
|
|
pm = null;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void canRegisterProject(){
|
2018-11-17 21:42:34 +01:00
|
|
|
|
2013-03-23 23:46:20 +01:00
|
|
|
SUT.registerProject(project, metadata);
|
|
|
|
|
2018-11-17 21:42:34 +01:00
|
|
|
AssertProjectRegistered();
|
|
|
|
verify(metadata, times(1)).getTags();
|
|
|
|
|
2013-03-23 23:46:20 +01:00
|
|
|
verifyNoMoreInteractions(project);
|
|
|
|
verifyNoMoreInteractions(metadata);
|
|
|
|
}
|
|
|
|
|
|
|
|
//TODO test registerProject in race condition
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void canEnsureProjectSave(){
|
|
|
|
whenGetSaveTimes(project, metadata);
|
|
|
|
registerProject();
|
|
|
|
|
|
|
|
//run test
|
|
|
|
SUT.ensureProjectSaved(project.id);
|
|
|
|
|
2018-11-17 21:42:34 +01:00
|
|
|
//assert and verify
|
2013-03-23 23:46:20 +01:00
|
|
|
AssertProjectRegistered();
|
|
|
|
try {
|
2018-11-17 21:42:34 +01:00
|
|
|
verify(SUT, times(1)).saveMetadata(metadata, project.id);
|
2013-03-23 23:46:20 +01:00
|
|
|
} catch (Exception e) {
|
|
|
|
Assert.fail();
|
|
|
|
}
|
|
|
|
this.verifySaveTimeCompared(1);
|
2018-11-17 21:42:34 +01:00
|
|
|
verify(SUT, times(1)).saveProject(project);
|
|
|
|
verify(metadata, times(1)).getTags();
|
2017-12-07 00:59:36 +01:00
|
|
|
|
2013-03-23 23:46:20 +01:00
|
|
|
//ensure end
|
|
|
|
verifyNoMoreInteractions(project);
|
|
|
|
verifyNoMoreInteractions(metadata);
|
|
|
|
}
|
|
|
|
|
|
|
|
//TODO test ensureProjectSave in race condition
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void canSaveAllModified(){
|
|
|
|
whenGetSaveTimes(project, metadata); //5 minute difference
|
|
|
|
registerProject(project, metadata);
|
|
|
|
|
2018-11-17 21:42:34 +01:00
|
|
|
//add a second project to the cache
|
2013-03-23 23:46:20 +01:00
|
|
|
Project project2 = spy(new ProjectStub(2));
|
|
|
|
ProjectMetadata metadata2 = mock(ProjectMetadata.class);
|
|
|
|
whenGetSaveTimes(project2, metadata2, 10); //not modified since the last save but within 30 seconds flush limit
|
|
|
|
registerProject(project2, metadata2);
|
|
|
|
|
2018-11-17 21:42:34 +01:00
|
|
|
//check that the two projects are not the same
|
2013-03-23 23:46:20 +01:00
|
|
|
Assert.assertFalse(project.id == project2.id);
|
|
|
|
|
|
|
|
SUT.save(true);
|
2018-11-17 21:42:34 +01:00
|
|
|
|
2013-03-23 23:46:20 +01:00
|
|
|
verifySaved(project, metadata);
|
2018-11-17 21:42:34 +01:00
|
|
|
|
|
|
|
verifySaved(project2, metadata2);
|
|
|
|
|
|
|
|
verify(SUT, times(1)).saveWorkspace();
|
2013-03-23 23:46:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void canFlushFromCache(){
|
|
|
|
|
|
|
|
whenGetSaveTimes(project, metadata, -10 );//already saved (10 seconds before)
|
|
|
|
registerProject(project, metadata);
|
|
|
|
Assert.assertSame(SUT.getProject(0), project);
|
|
|
|
|
|
|
|
SUT.save(true);
|
|
|
|
|
2018-11-17 21:42:34 +01:00
|
|
|
verify(metadata, times(1)).getModified();
|
|
|
|
verify(metadata, times(1)).getTags();
|
|
|
|
verify(project, times(1)).getProcessManager();
|
|
|
|
verify(project, times(2)).getLastSave();
|
|
|
|
verify(project, times(1)).dispose();
|
2013-03-23 23:46:20 +01:00
|
|
|
verify(SUT, never()).saveProject(project);
|
|
|
|
Assert.assertEquals(SUT.getProject(0), null);
|
|
|
|
verifyNoMoreInteractions(project);
|
|
|
|
verifyNoMoreInteractions(metadata);
|
|
|
|
|
2018-11-17 21:42:34 +01:00
|
|
|
verify(SUT, times(1)).saveWorkspace();
|
2013-03-23 23:46:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void cannotSaveWhenBusy(){
|
|
|
|
registerProject();
|
|
|
|
SUT.setBusy(true);
|
|
|
|
|
|
|
|
SUT.save(false);
|
|
|
|
|
|
|
|
verify(SUT, never()).saveProjects(Mockito.anyBoolean());
|
|
|
|
verify(SUT, never()).saveWorkspace();
|
2018-11-17 21:42:34 +01:00
|
|
|
verify(metadata, times(1)).getTags();
|
2013-03-23 23:46:20 +01:00
|
|
|
verifyNoMoreInteractions(project);
|
|
|
|
verifyNoMoreInteractions(metadata);
|
|
|
|
}
|
|
|
|
|
|
|
|
//TODO test canSaveAllModifiedWithRaceCondition
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void canSaveSomeModified(){
|
|
|
|
registerProject();
|
|
|
|
whenGetSaveTimes(project, metadata );
|
|
|
|
|
|
|
|
SUT.save(false); //not busy
|
|
|
|
|
|
|
|
verifySaved(project, metadata);
|
2018-11-17 21:42:34 +01:00
|
|
|
verify(SUT, times(1)).saveWorkspace();
|
2013-03-23 23:46:20 +01:00
|
|
|
|
|
|
|
}
|
|
|
|
//TODO test canSaveAllModifiedWithRaceCondition
|
|
|
|
|
|
|
|
//-------------helpers-------------
|
|
|
|
|
|
|
|
protected void registerProject(){
|
2018-11-17 21:42:34 +01:00
|
|
|
this.registerProject(project, metadata);
|
2013-03-23 23:46:20 +01:00
|
|
|
}
|
2018-11-17 21:42:34 +01:00
|
|
|
protected void registerProject(Project proj, ProjectMetadata meta){
|
|
|
|
SUT.registerProject(proj, meta);
|
2013-03-23 23:46:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
protected void AssertProjectRegistered(){
|
|
|
|
Assert.assertEquals(SUT.getProject(project.id), project);
|
|
|
|
Assert.assertEquals(SUT.getProjectMetadata(project.id), metadata);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected void whenGetSaveTimes(Project proj, ProjectMetadata meta){
|
|
|
|
whenGetSaveTimes(proj, meta, 5);
|
|
|
|
}
|
|
|
|
protected void whenGetSaveTimes(Project proj, ProjectMetadata meta, int secondsDifference){
|
|
|
|
whenProjectGetLastSave(proj);
|
|
|
|
whenMetadataGetModified(meta, secondsDifference);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected void whenProjectGetLastSave(Project proj){
|
2017-12-15 21:24:09 +01:00
|
|
|
LocalDateTime projectLastSaveDate = LocalDateTime.of(1970,01,02,00,30,00);
|
2013-03-23 23:46:20 +01:00
|
|
|
when(proj.getLastSave()).thenReturn(projectLastSaveDate);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected void whenMetadataGetModified(ProjectMetadata meta){
|
|
|
|
whenMetadataGetModified(meta, 5*60);
|
|
|
|
}
|
|
|
|
protected void whenMetadataGetModified(ProjectMetadata meta, int secondsDifference){
|
2017-12-15 21:24:09 +01:00
|
|
|
LocalDateTime metadataModifiedDate = LocalDateTime.of(1970,01,02,00, 30 + secondsDifference);
|
2013-03-23 23:46:20 +01:00
|
|
|
when(meta.getModified()).thenReturn(metadataModifiedDate);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected void verifySaveTimeCompared(int times){
|
|
|
|
verifySaveTimeCompared(project, metadata, times);
|
|
|
|
}
|
|
|
|
protected void verifySaveTimeCompared(Project project, ProjectMetadata metadata, int times){
|
|
|
|
verify(metadata, times(times)).getModified();
|
|
|
|
verify(project, times(times)).getLastSave();
|
|
|
|
}
|
2018-11-17 21:42:34 +01:00
|
|
|
|
2013-03-23 23:46:20 +01:00
|
|
|
protected void verifySaved(Project proj, ProjectMetadata meta){
|
2018-11-17 21:42:34 +01:00
|
|
|
verify(meta, times(1)).getModified();
|
|
|
|
verify(proj, times(2)).getLastSave();
|
|
|
|
verify(SUT, times(1)).saveProject(proj);
|
|
|
|
verify(meta, times(1)).getTags();
|
2013-03-23 23:46:20 +01:00
|
|
|
|
|
|
|
verifyNoMoreInteractions(proj);
|
|
|
|
verifyNoMoreInteractions(meta);
|
|
|
|
}
|
|
|
|
}
|