/* ***** BEGIN LICENSE BLOCK *****
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
*
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
* for the specific language governing rights and limitations under the
* License.
*
* The Original Code is part of dcm4che, an implementation of DICOM(TM) in
* Java(TM), hosted at https://github.com/gunterze/dcm4che.
*
* The Initial Developer of the Original Code is
* Agfa Healthcare.
* Portions created by the Initial Developer are Copyright (C) 2011
* the Initial Developer. All Rights Reserved.
*
* Contributor(s):
* See @authors listed below
*
* Alternatively, the contents of this file may be used under the terms of
* either the GNU General Public License Version 2 or later (the "GPL"), or
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
* in which case the provisions of the GPL or the LGPL are applicable instead
* of those above. If you wish to allow use of your version of this file only
* under the terms of either the GPL or the LGPL, and not to allow others to
* use your version of this file under the terms of the MPL, indicate your
* decision by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL or the LGPL. If you do not delete
* the provisions above, a recipient may use your version of this file under
* the terms of any one of the MPL, the GPL or the LGPL.
*
* ***** END LICENSE BLOCK ***** */
package org.dcm4chee.archive.hsm;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue;
import java.util.List;
import org.dcm4chee.archive.conf.ArchiveAEExtension;
import org.dcm4chee.archive.conf.ArchivingRule;
import org.dcm4chee.archive.entity.ArchivingTask;
import org.dcm4chee.archive.entity.Location;
import org.jboss.arquillian.container.test.api.Deployment;
import org.jboss.arquillian.junit.Arquillian;
import org.jboss.shrinkwrap.api.spec.WebArchive;
import org.junit.Test;
import org.junit.runner.RunWith;
/**
* @author Franz Willer <franz.willer@gmail.com>
*
*/
@RunWith(Arquillian.class)
public class HsmArchiveIT extends HsmITBase {
@Deployment
public static WebArchive createDeployment() {
return createDeployment(HsmArchiveIT.class);
}
@Test
public void testStoreSingleNoArchivingRule() throws Exception {
store(RESOURCES_STUDY_1_2SERIES[0], arcAEExt);
List<Location> locations = getLocations(FIRST_INSTANCE_STUDY_1);
assertEquals("#Locations for "+FIRST_INSTANCE_STUDY_1, 1, locations.size());
}
@Test
public void testStoreStudyNoArchivingRule() throws Exception {
ArchiveAEExtension arcAEExt = getConfiguredAEExtension((ArchivingRule[])null);
store(RESOURCES_STUDY_1_2SERIES, arcAEExt);
checkLocationsOfStudy(STUDY_INSTANCE_UID_1, RESOURCES_STUDY_1_2SERIES.length, 1);
}
@Test
public void testStoreOneSeriesOneArchivingRule() throws Exception {
ArchivingRule rule = new ArchivingRule();
rule.setAeTitles(new String[]{SOURCE_AET});
rule.setDelayAfterInstanceStored(1);
rule.setStorageSystemGroupIDs(TEST_NEARLINE_ZIP);
ArchiveAEExtension arcAEExt = getConfiguredAEExtension(rule);
store(RESOURCES_STUDY_2_1SERIES, arcAEExt);
List<ArchivingTask> tasks = getArchivingTasks(SERIES_INSTANCE_UID_2_1);
assertEquals("#ArchivingTasks for "+SERIES_INSTANCE_UID_2_1, 1, tasks.size());
List<Location> locations = getLocations(FIRST_INSTANCE_STUDY_2);
assertEquals("#Locations for "+FIRST_INSTANCE_STUDY_2, 1, locations.size());
waitForFinishedTasks(2, DEFAULT_TASK_TIMEOUT, 5, DEFAULT_WAIT_AFTER);
checkLocationsOfStudy(STUDY_INSTANCE_UID_2, RESOURCES_STUDY_2_1SERIES.length, 2);
}
@Test
public void testStoreTwoSeriesOneArchivingRule() throws Exception {
ArchivingRule rule = new ArchivingRule();
rule.setAeTitles(new String[]{SOURCE_AET});
rule.setDelayAfterInstanceStored(1);
rule.setStorageSystemGroupIDs(TEST_NEARLINE_ZIP);
ArchiveAEExtension arcAEExt = getConfiguredAEExtension(rule);
store(RESOURCES_STUDY_1_2SERIES, arcAEExt);
List<ArchivingTask> tasks = getArchivingTasks(SERIES_INSTANCE_UID_1_1);
assertEquals("#ArchivingTasks for "+SERIES_INSTANCE_UID_1_1, 1, tasks.size());
tasks = getArchivingTasks(SERIES_INSTANCE_UID_1_2);
assertEquals("#ArchivingTasks for "+SERIES_INSTANCE_UID_1_2, 1, tasks.size());
waitForFinishedTasks(2, DEFAULT_TASK_TIMEOUT, 5, DEFAULT_WAIT_AFTER);
checkLocationsOfStudy(STUDY_INSTANCE_UID_1, RESOURCES_STUDY_1_2SERIES.length, 2);
}
@Test
public void testStoreTwoRules() throws Exception {
ArchivingRule rule1 = new ArchivingRule();
rule1.setAeTitles(new String[]{SOURCE_AET});
rule1.setDelayAfterInstanceStored(1);
rule1.setStorageSystemGroupIDs(TEST_NEARLINE_ZIP);
rule1.setCommonName(TEST_NEARLINE_ZIP);
ArchivingRule rule2 = new ArchivingRule();
rule2.setAeTitles(new String[]{SOURCE_AET});
rule2.setDelayAfterInstanceStored(1);
rule2.setStorageSystemGroupIDs(TEST_NEARLINE_TAR);
rule2.setCommonName(TEST_NEARLINE_TAR);
ArchiveAEExtension arcAEExt = getConfiguredAEExtension(rule1, rule2);
store(HsmITBase.RESOURCES_STUDY_2_1SERIES, arcAEExt);
List<ArchivingTask> tasks = getArchivingTasks(SERIES_INSTANCE_UID_2_1);
assertEquals("#ArchivingTasks for "+SERIES_INSTANCE_UID_2_1, 2, tasks.size());
List<Location> locations = getLocations(FIRST_INSTANCE_STUDY_2);
assertEquals("#Locations for "+FIRST_INSTANCE_STUDY_2, 1, locations.size());
waitForFinishedTasks(2, DEFAULT_TASK_TIMEOUT, 10, DEFAULT_WAIT_AFTER);
locations = getLocations(FIRST_INSTANCE_STUDY_2);
assertEquals("#Locations for "+FIRST_INSTANCE_STUDY_2, 3, locations.size());
checkStorageSystemGroups(checkLocationsOfStudy(STUDY_INSTANCE_UID_2, RESOURCES_STUDY_2_1SERIES.length, 3),
true, TEST_ONLINE, TEST_NEARLINE_ZIP, TEST_NEARLINE_TAR);
}
@Test
public void testStoreOneRuleTwoTargets() throws Exception {
ArchivingRule rule = new ArchivingRule();
rule.setAeTitles(new String[]{SOURCE_AET});
rule.setDelayAfterInstanceStored(1);
rule.setStorageSystemGroupIDs(TEST_NEARLINE_ZIP,TEST_NEARLINE_TAR);
rule.setCommonName("ZIPandTAR");
ArchiveAEExtension arcAEExt = getConfiguredAEExtension(rule);
store(HsmITBase.RESOURCES_STUDY_2_1SERIES, arcAEExt);
List<ArchivingTask> tasks = getArchivingTasks(SERIES_INSTANCE_UID_2_1);
assertEquals("#ArchivingTasks for "+SERIES_INSTANCE_UID_2_1, 2, tasks.size());
List<Location> locations = getLocations(FIRST_INSTANCE_STUDY_2);
assertEquals("#Locations for "+FIRST_INSTANCE_STUDY_2, 1, locations.size());
waitForFinishedTasks(2, DEFAULT_TASK_TIMEOUT, 10, DEFAULT_WAIT_AFTER);
locations = getLocations(FIRST_INSTANCE_STUDY_2);
assertEquals("#Locations for "+FIRST_INSTANCE_STUDY_2, 3, locations.size());
checkStorageSystemGroups(checkLocationsOfStudy(STUDY_INSTANCE_UID_2, RESOURCES_STUDY_2_1SERIES.length, 3),
true, TEST_ONLINE, TEST_NEARLINE_ZIP, TEST_NEARLINE_TAR);
}
@Test
public void testArchivingTimeUpdate() throws Exception {
ArchivingRule rule = new ArchivingRule();
rule.setAeTitles(new String[]{SOURCE_AET});
rule.setDelayAfterInstanceStored(2);
rule.setStorageSystemGroupIDs(TEST_NEARLINE_ZIP);
ArchiveAEExtension arcAEExt = getConfiguredAEExtension(rule);
store(RESOURCES_STUDY_2_1SERIES[0], arcAEExt);
List<ArchivingTask> tasks = getArchivingTasks(SERIES_INSTANCE_UID_2_1);
assertEquals("#ArchivingTasks for "+SERIES_INSTANCE_UID_2_1, 1, tasks.size());
long firstArchivingTime = tasks.get(0).getArchivingTime().getTime();
waitForFinishedTasks(0, 0, 0, 500);
store(RESOURCES_STUDY_2_1SERIES[1], arcAEExt);
waitForFinishedTasks(0, 0, 0, 500);
tasks = getArchivingTasks(SERIES_INSTANCE_UID_2_1);
assertEquals("#ArchivingTasks for "+SERIES_INSTANCE_UID_2_1, 1, tasks.size());
long secondArchivingTime = tasks.get(0).getArchivingTime().getTime();
assertTrue("New ArchivingTime ("+secondArchivingTime+") > first ArchivingTime ("+firstArchivingTime+")+400ms", secondArchivingTime > firstArchivingTime+400);
}
}