summaryrefslogtreecommitdiffstats
path: root/src/test/java/org/openslx/virtualization/configuration/logic
diff options
context:
space:
mode:
Diffstat (limited to 'src/test/java/org/openslx/virtualization/configuration/logic')
-rw-r--r--src/test/java/org/openslx/virtualization/configuration/logic/ConfigurationLogicDozModClientToDozModServerTest.java92
-rw-r--r--src/test/java/org/openslx/virtualization/configuration/logic/ConfigurationLogicDozModServerToDozModClientTest.java108
-rw-r--r--src/test/java/org/openslx/virtualization/configuration/logic/ConfigurationLogicDozModServerToStatelessClientTest.java102
-rw-r--r--src/test/java/org/openslx/virtualization/configuration/logic/ConfigurationLogicTestResources.java32
-rw-r--r--src/test/java/org/openslx/virtualization/configuration/logic/ConfigurationLogicTestUtils.java100
5 files changed, 434 insertions, 0 deletions
diff --git a/src/test/java/org/openslx/virtualization/configuration/logic/ConfigurationLogicDozModClientToDozModServerTest.java b/src/test/java/org/openslx/virtualization/configuration/logic/ConfigurationLogicDozModClientToDozModServerTest.java
new file mode 100644
index 0000000..f078b5e
--- /dev/null
+++ b/src/test/java/org/openslx/virtualization/configuration/logic/ConfigurationLogicDozModClientToDozModServerTest.java
@@ -0,0 +1,92 @@
+package org.openslx.virtualization.configuration.logic;
+
+import static org.junit.jupiter.api.Assertions.assertDoesNotThrow;
+import static org.junit.jupiter.api.Assertions.assertTrue;
+
+import java.io.File;
+
+import org.apache.log4j.Level;
+import org.apache.log4j.LogManager;
+import org.junit.jupiter.api.BeforeAll;
+import org.junit.jupiter.api.DisplayName;
+import org.junit.jupiter.api.Test;
+import org.openslx.libvirt.xml.LibvirtXmlTestResources;
+import org.openslx.virtualization.configuration.VirtualizationConfiguration;
+import org.openslx.virtualization.configuration.data.ConfigurationDataDozModClientToDozModServer;
+import org.openslx.virtualization.configuration.transformation.TransformationException;
+
+public class ConfigurationLogicDozModClientToDozModServerTest
+{
+ @BeforeAll
+ public static void setUp()
+ {
+ // disable logging with log4j
+ LogManager.getRootLogger().setLevel( Level.OFF );
+ }
+
+ @Test
+ @DisplayName( "Test transformation logic between a dozmod-client and a dozmod-server for Libvirt/QEMU configuration" )
+ public void testConfigurationLogicDozModClientToDozModServerLibvirt() throws TransformationException
+ {
+ final String inputConfigFileName = "qemu-kvm_default-ubuntu-20-04-vm.xml";
+ final String expectedConfigFileName = "qemu-kvm_default-ubuntu-20-04-vm_transform-privacy.xml";
+ final File inputConfig = LibvirtXmlTestResources.getLibvirtXmlFile( inputConfigFileName );
+ final File expectedConfig = LibvirtXmlTestResources.getLibvirtXmlFile( expectedConfigFileName );
+ final VirtualizationConfiguration<?, ?, ?, ?> config;
+ config = ConfigurationLogicTestUtils.newVirtualizationConfigurationInstance( inputConfig );
+ final ConfigurationLogicDozModClientToDozModServer logic = new ConfigurationLogicDozModClientToDozModServer();
+
+ logic.apply( config, new ConfigurationDataDozModClientToDozModServer() );
+
+ final String transformedConfig = config.getConfigurationAsString();
+ final String expectedTransformedConfig = ConfigurationLogicTestUtils.readFileToString( expectedConfig );
+
+ assertTrue( ConfigurationLogicTestUtils.isContentEqual( expectedTransformedConfig, transformedConfig ) );
+ assertDoesNotThrow( () -> config.validate() );
+ }
+
+ @Test
+ @DisplayName( "Test transformation logic between a dozmod-client and a dozmod-server for VirtualBox configuration" )
+ public void testConfigurationLogicDozModClientToDozModServerVirtualBox() throws TransformationException
+ {
+ final String inputConfigFileName = "virtualbox_default-ubuntu.vbox";
+ final String expectedConfigFileName = "virtualbox_default-ubuntu_transform-privacy.vbox";
+ final File inputConfig = ConfigurationLogicTestResources.getVirtualBoxXmlFile( inputConfigFileName );
+ final File expectedConfig = ConfigurationLogicTestResources.getVirtualBoxXmlFile( expectedConfigFileName );
+ final VirtualizationConfiguration<?, ?, ?, ?> config;
+ config = ConfigurationLogicTestUtils.newVirtualizationConfigurationInstance( inputConfig );
+ final ConfigurationLogicDozModClientToDozModServer logic = new ConfigurationLogicDozModClientToDozModServer();
+
+ logic.apply( config, new ConfigurationDataDozModClientToDozModServer() );
+
+ final String transformedConfig = config.getConfigurationAsString();
+ final String expectedTransformedConfig = ConfigurationLogicTestUtils.readFileToString( expectedConfig );
+
+ assertTrue( ConfigurationLogicTestUtils.isContentEqual( expectedTransformedConfig, transformedConfig ) );
+
+ // do not validate the VirtualBox configuration afterwards, since the inserted
+ // place holders do not match valid primitive values from the XML schema
+ //assertDoesNotThrow( () -> config.validate() );
+ }
+
+ @Test
+ @DisplayName( "Test transformation logic between a dozmod-client and a dozmod-server for VMware configuration" )
+ public void testConfigurationLogicDozModClientToDozModServerVmware() throws TransformationException
+ {
+ final String inputConfigFileName = "vmware-player_default-ubuntu.vmx";
+ final String expectedConfigFileName = "vmware-player_default-ubuntu_transform-privacy.vmx";
+ final File inputConfig = ConfigurationLogicTestResources.getVmwareVmxFile( inputConfigFileName );
+ final File expectedConfig = ConfigurationLogicTestResources.getVmwareVmxFile( expectedConfigFileName );
+ final VirtualizationConfiguration<?, ?, ?, ?> config;
+ config = ConfigurationLogicTestUtils.newVirtualizationConfigurationInstance( inputConfig );
+ final ConfigurationLogicDozModClientToDozModServer logic = new ConfigurationLogicDozModClientToDozModServer();
+
+ logic.apply( config, new ConfigurationDataDozModClientToDozModServer() );
+
+ final String transformedConfig = config.getConfigurationAsString();
+ final String expectedTransformedConfig = ConfigurationLogicTestUtils.readFileToString( expectedConfig );
+
+ assertTrue( ConfigurationLogicTestUtils.isContentEqual( expectedTransformedConfig, transformedConfig ) );
+ assertDoesNotThrow( () -> config.validate() );
+ }
+}
diff --git a/src/test/java/org/openslx/virtualization/configuration/logic/ConfigurationLogicDozModServerToDozModClientTest.java b/src/test/java/org/openslx/virtualization/configuration/logic/ConfigurationLogicDozModServerToDozModClientTest.java
new file mode 100644
index 0000000..96180ed
--- /dev/null
+++ b/src/test/java/org/openslx/virtualization/configuration/logic/ConfigurationLogicDozModServerToDozModClientTest.java
@@ -0,0 +1,108 @@
+package org.openslx.virtualization.configuration.logic;
+
+import static org.junit.jupiter.api.Assertions.assertDoesNotThrow;
+import static org.junit.jupiter.api.Assertions.assertTrue;
+
+import java.io.File;
+
+import org.apache.log4j.Level;
+import org.apache.log4j.LogManager;
+import org.junit.jupiter.api.BeforeAll;
+import org.junit.jupiter.api.DisplayName;
+import org.junit.jupiter.api.Test;
+import org.openslx.bwlp.thrift.iface.OperatingSystem;
+import org.openslx.libvirt.xml.LibvirtXmlTestResources;
+import org.openslx.virtualization.configuration.VirtualizationConfiguration;
+import org.openslx.virtualization.configuration.data.ConfigurationDataDozModServerToDozModClient;
+import org.openslx.virtualization.configuration.transformation.TransformationException;
+import org.openslx.vm.disk.DiskImageTestResources;
+
+public class ConfigurationLogicDozModServerToDozModClientTest
+{
+ private static final String DEFAULT_DISPLAY_NAME = "Test";
+ private static final File DEFAULT_DISK_IMAGE = DiskImageTestResources.getDiskFile( "image-default.vmdk" );
+ private static final OperatingSystem DEFAULT_GUEST_OS = null;
+ private static final String DEFAULT_VIRTUALIZER_ID = null;
+ private static final int DEFAULT_TOTAL_MEMORY = 4096;
+
+ private static final ConfigurationDataDozModServerToDozModClient DEFAULT_CONFIG_DATA = new ConfigurationDataDozModServerToDozModClient(
+ ConfigurationLogicDozModServerToDozModClientTest.DEFAULT_DISPLAY_NAME,
+ ConfigurationLogicDozModServerToDozModClientTest.DEFAULT_DISK_IMAGE,
+ ConfigurationLogicDozModServerToDozModClientTest.DEFAULT_GUEST_OS,
+ ConfigurationLogicDozModServerToDozModClientTest.DEFAULT_VIRTUALIZER_ID,
+ ConfigurationLogicDozModServerToDozModClientTest.DEFAULT_TOTAL_MEMORY );
+
+ @BeforeAll
+ public static void setUp()
+ {
+ // disable logging with log4j
+ LogManager.getRootLogger().setLevel( Level.OFF );
+ }
+
+ @Test
+ @DisplayName( "Test transformation logic between a dozmod-server and a dozmod-client for Libvirt/QEMU configuration" )
+ public void testConfigurationLogicDozModServerToDozModClientLibvirt() throws TransformationException
+ {
+ final String inputConfigFileName = "qemu-kvm_default-ubuntu-20-04-vm_transform-privacy.xml";
+ final String expectedConfigFileName = "qemu-kvm_default-ubuntu-20-04-vm_transform-editable.xml";
+ final File inputConfig = LibvirtXmlTestResources.getLibvirtXmlFile( inputConfigFileName );
+ final File expectedConfig = LibvirtXmlTestResources.getLibvirtXmlFile( expectedConfigFileName );
+ final VirtualizationConfiguration<?, ?, ?, ?> config;
+ config = ConfigurationLogicTestUtils.newVirtualizationConfigurationInstance( inputConfig );
+ final ConfigurationLogicDozModServerToDozModClient logic = new ConfigurationLogicDozModServerToDozModClient();
+
+ logic.apply( config, ConfigurationLogicDozModServerToDozModClientTest.DEFAULT_CONFIG_DATA );
+
+ final String transformedConfig = config.getConfigurationAsString();
+ final String expectedTransformedConfig = ConfigurationLogicTestUtils.readFileToString( expectedConfig );
+
+ assertTrue( ConfigurationLogicTestUtils.isContentEqual( expectedTransformedConfig, transformedConfig ) );
+ assertDoesNotThrow( () -> config.validate() );
+ }
+
+ @Test
+ @DisplayName( "Test transformation logic between a dozmod-server and a dozmod-client for VirtualBox configuration" )
+ public void testConfigurationLogicDozModServerToDozModClientVirtualBox() throws TransformationException
+ {
+ final String inputConfigFileName = "virtualbox_default-ubuntu_transform-privacy.vbox";
+ final String expectedConfigFileName = "virtualbox_default-ubuntu_transform-editable.vbox";
+ final File inputConfig = ConfigurationLogicTestResources.getVirtualBoxXmlFile( inputConfigFileName );
+ final File expectedConfig = ConfigurationLogicTestResources.getVirtualBoxXmlFile( expectedConfigFileName );
+ final VirtualizationConfiguration<?, ?, ?, ?> config;
+ config = ConfigurationLogicTestUtils.newVirtualizationConfigurationInstance( inputConfig );
+ final ConfigurationLogicDozModServerToDozModClient logic = new ConfigurationLogicDozModServerToDozModClient();
+
+ logic.apply( config, ConfigurationLogicDozModServerToDozModClientTest.DEFAULT_CONFIG_DATA );
+
+ final String transformedConfig = config.getConfigurationAsString();
+ final String expectedTransformedConfig = ConfigurationLogicTestUtils.readFileToString( expectedConfig );
+
+ assertTrue(
+ ConfigurationLogicTestUtils.isVirtualBoxContentEqual( expectedTransformedConfig, transformedConfig ) );
+
+ // do not validate the VirtualBox configuration afterwards, since the inserted network configuration
+ // leads to an invalid DOM although the created output after the transformation is as expected
+ //assertDoesNotThrow( () -> config.validate() );
+ }
+
+ @Test
+ @DisplayName( "Test transformation logic between dozmod-server and a dozmod-client for VMware configuration" )
+ public void testConfigurationLogicDozModServerToDozModClientVmware() throws TransformationException
+ {
+ final String inputConfigFileName = "vmware-player_default-ubuntu_transform-privacy.vmx";
+ final String expectedConfigFileName = "vmware-player_default-ubuntu_transform-editable.vmx";
+ final File inputConfig = ConfigurationLogicTestResources.getVmwareVmxFile( inputConfigFileName );
+ final File expectedConfig = ConfigurationLogicTestResources.getVmwareVmxFile( expectedConfigFileName );
+ final VirtualizationConfiguration<?, ?, ?, ?> config;
+ config = ConfigurationLogicTestUtils.newVirtualizationConfigurationInstance( inputConfig );
+ final ConfigurationLogicDozModServerToDozModClient logic = new ConfigurationLogicDozModServerToDozModClient();
+
+ logic.apply( config, ConfigurationLogicDozModServerToDozModClientTest.DEFAULT_CONFIG_DATA );
+
+ final String transformedConfig = config.getConfigurationAsString();
+ final String expectedTransformedConfig = ConfigurationLogicTestUtils.readFileToString( expectedConfig );
+
+ assertTrue( ConfigurationLogicTestUtils.isContentEqual( expectedTransformedConfig, transformedConfig ) );
+ assertDoesNotThrow( () -> config.validate() );
+ }
+}
diff --git a/src/test/java/org/openslx/virtualization/configuration/logic/ConfigurationLogicDozModServerToStatelessClientTest.java b/src/test/java/org/openslx/virtualization/configuration/logic/ConfigurationLogicDozModServerToStatelessClientTest.java
new file mode 100644
index 0000000..6c87526
--- /dev/null
+++ b/src/test/java/org/openslx/virtualization/configuration/logic/ConfigurationLogicDozModServerToStatelessClientTest.java
@@ -0,0 +1,102 @@
+package org.openslx.virtualization.configuration.logic;
+
+import static org.junit.jupiter.api.Assertions.assertDoesNotThrow;
+import static org.junit.jupiter.api.Assertions.assertTrue;
+
+import java.io.File;
+
+import org.apache.log4j.Level;
+import org.apache.log4j.LogManager;
+import org.junit.jupiter.api.BeforeAll;
+import org.junit.jupiter.api.DisplayName;
+import org.junit.jupiter.api.Test;
+import org.openslx.libvirt.xml.LibvirtXmlTestResources;
+import org.openslx.virtualization.configuration.VirtualizationConfiguration;
+import org.openslx.virtualization.configuration.data.ConfigurationDataDozModServerToStatelessClient;
+import org.openslx.virtualization.configuration.transformation.TransformationException;
+
+public class ConfigurationLogicDozModServerToStatelessClientTest
+{
+ private static final String DEFAULT_DISPLAY_NAME = "Test";
+ private static final String DEFAULT_OS_ID = null;
+ private static final boolean DEFAULT_HAS_USB_ACCESS = true;
+
+ private static final ConfigurationDataDozModServerToStatelessClient DEFAULT_CONFIG_DATA = new ConfigurationDataDozModServerToStatelessClient(
+ ConfigurationLogicDozModServerToStatelessClientTest.DEFAULT_DISPLAY_NAME,
+ ConfigurationLogicDozModServerToStatelessClientTest.DEFAULT_OS_ID,
+ ConfigurationLogicDozModServerToStatelessClientTest.DEFAULT_HAS_USB_ACCESS );
+
+ @BeforeAll
+ public static void setUp()
+ {
+ // disable logging with log4j
+ LogManager.getRootLogger().setLevel( Level.OFF );
+ }
+
+ @Test
+ @DisplayName( "Test transformation logic between a dozmod-server and a stateless client for Libvirt/QEMU configuration" )
+ public void testConfigurationLogicDozModServerToStatelessClientLibvirt() throws TransformationException
+ {
+ final String inputConfigFileName = "qemu-kvm_default-ubuntu-20-04-vm_transform-privacy.xml";
+ final String expectedConfigFileName = "qemu-kvm_default-ubuntu-20-04-vm_transform-non-persistent.xml";
+ final File inputConfig = LibvirtXmlTestResources.getLibvirtXmlFile( inputConfigFileName );
+ final File expectedConfig = LibvirtXmlTestResources.getLibvirtXmlFile( expectedConfigFileName );
+ final VirtualizationConfiguration<?, ?, ?, ?> config;
+ config = ConfigurationLogicTestUtils.newVirtualizationConfigurationInstance( inputConfig );
+ final ConfigurationLogicDozModServerToStatelessClient logic = new ConfigurationLogicDozModServerToStatelessClient();
+
+ logic.apply( config, ConfigurationLogicDozModServerToStatelessClientTest.DEFAULT_CONFIG_DATA );
+
+ final String transformedConfig = config.getConfigurationAsString();
+ final String expectedTransformedConfig = ConfigurationLogicTestUtils.readFileToString( expectedConfig );
+
+ assertTrue( ConfigurationLogicTestUtils.isContentEqual( expectedTransformedConfig, transformedConfig ) );
+ assertDoesNotThrow( () -> config.validate() );
+ }
+
+ @Test
+ @DisplayName( "Test transformation logic between a dozmod-server and a stateless client for VirtualBox configuration" )
+ public void testConfigurationLogicDozModServerToStatelessClientVirtualBox() throws TransformationException
+ {
+ final String inputConfigFileName = "virtualbox_default-ubuntu_transform-privacy.vbox";
+ final String expectedConfigFileName = "virtualbox_default-ubuntu_transform-non-persistent.vbox";
+ final File inputConfig = ConfigurationLogicTestResources.getVirtualBoxXmlFile( inputConfigFileName );
+ final File expectedConfig = ConfigurationLogicTestResources.getVirtualBoxXmlFile( expectedConfigFileName );
+ final VirtualizationConfiguration<?, ?, ?, ?> config;
+ config = ConfigurationLogicTestUtils.newVirtualizationConfigurationInstance( inputConfig );
+ final ConfigurationLogicDozModServerToStatelessClient logic = new ConfigurationLogicDozModServerToStatelessClient();
+
+ logic.apply( config, ConfigurationLogicDozModServerToStatelessClientTest.DEFAULT_CONFIG_DATA );
+
+ final String transformedConfig = config.getConfigurationAsString();
+ final String expectedTransformedConfig = ConfigurationLogicTestUtils.readFileToString( expectedConfig );
+
+ assertTrue(
+ ConfigurationLogicTestUtils.isVirtualBoxContentEqual( expectedTransformedConfig, transformedConfig ) );
+
+ // do not validate the VirtualBox configuration afterwards, since the inserted
+ // place holders do not match valid primitive values from the XML schema
+ //assertDoesNotThrow( () -> config.validate() );
+ }
+
+ @Test
+ @DisplayName( "Test transformation logic between dozmod-server and a stateless client for VMware configuration" )
+ public void testConfigurationLogicDozModServerToStatelessClientVmware() throws TransformationException
+ {
+ final String inputConfigFileName = "vmware-player_default-ubuntu_transform-privacy.vmx";
+ final String expectedConfigFileName = "vmware-player_default-ubuntu_transform-non-persistent.vmx";
+ final File inputConfig = ConfigurationLogicTestResources.getVmwareVmxFile( inputConfigFileName );
+ final File expectedConfig = ConfigurationLogicTestResources.getVmwareVmxFile( expectedConfigFileName );
+ final VirtualizationConfiguration<?, ?, ?, ?> config;
+ config = ConfigurationLogicTestUtils.newVirtualizationConfigurationInstance( inputConfig );
+ final ConfigurationLogicDozModServerToStatelessClient logic = new ConfigurationLogicDozModServerToStatelessClient();
+
+ logic.apply( config, ConfigurationLogicDozModServerToStatelessClientTest.DEFAULT_CONFIG_DATA );
+
+ final String transformedConfig = config.getConfigurationAsString();
+ final String expectedTransformedConfig = ConfigurationLogicTestUtils.readFileToString( expectedConfig );
+
+ assertTrue( ConfigurationLogicTestUtils.isContentEqual( expectedTransformedConfig, transformedConfig ) );
+ assertDoesNotThrow( () -> config.validate() );
+ }
+}
diff --git a/src/test/java/org/openslx/virtualization/configuration/logic/ConfigurationLogicTestResources.java b/src/test/java/org/openslx/virtualization/configuration/logic/ConfigurationLogicTestResources.java
new file mode 100644
index 0000000..ceafceb
--- /dev/null
+++ b/src/test/java/org/openslx/virtualization/configuration/logic/ConfigurationLogicTestResources.java
@@ -0,0 +1,32 @@
+package org.openslx.virtualization.configuration.logic;
+
+import java.io.File;
+import java.net.URL;
+
+public class ConfigurationLogicTestResources
+{
+ private static final String VMWARE_PREFIX_PATH = File.separator + "vmware";
+ private static final String VMWARE_PREFIX_PATH_VMX = VMWARE_PREFIX_PATH + File.separator + "vmx";
+
+ private static final String VIRTUALBOX_PREFIX_PATH = File.separator + "virtualbox";
+ private static final String VIRTUALBOX_PREFIX_PATH_XML = VIRTUALBOX_PREFIX_PATH + File.separator + "xml";
+
+ private static File getFile( String prefixPath, String fileName )
+ {
+ final String filePath = prefixPath + File.separator + fileName;
+ final URL fileUrl = ConfigurationLogicTestResources.class.getResource( filePath );
+ return new File( fileUrl.getFile() );
+ }
+
+ public static File getVmwareVmxFile( String vmwareVmxFileName )
+ {
+ return ConfigurationLogicTestResources.getFile( ConfigurationLogicTestResources.VMWARE_PREFIX_PATH_VMX,
+ vmwareVmxFileName );
+ }
+
+ public static File getVirtualBoxXmlFile( String virtualBoxXmlFileName )
+ {
+ return ConfigurationLogicTestResources.getFile( ConfigurationLogicTestResources.VIRTUALBOX_PREFIX_PATH_XML,
+ virtualBoxXmlFileName );
+ }
+}
diff --git a/src/test/java/org/openslx/virtualization/configuration/logic/ConfigurationLogicTestUtils.java b/src/test/java/org/openslx/virtualization/configuration/logic/ConfigurationLogicTestUtils.java
new file mode 100644
index 0000000..07046b5
--- /dev/null
+++ b/src/test/java/org/openslx/virtualization/configuration/logic/ConfigurationLogicTestUtils.java
@@ -0,0 +1,100 @@
+package org.openslx.virtualization.configuration.logic;
+
+import static org.junit.jupiter.api.Assertions.fail;
+
+import java.io.BufferedReader;
+import java.io.File;
+import java.io.IOException;
+import java.io.StringReader;
+import java.nio.charset.StandardCharsets;
+import java.util.Arrays;
+import java.util.Collections;
+import java.util.List;
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
+import java.util.stream.Collectors;
+
+import org.apache.commons.io.FileUtils;
+import org.openslx.bwlp.thrift.iface.OperatingSystem;
+import org.openslx.virtualization.configuration.VirtualizationConfiguration;
+
+public class ConfigurationLogicTestUtils
+{
+ // @formatter:off
+ public static final List<OperatingSystem> STUB_OS_LIST = Collections.unmodifiableList( Arrays.asList(
+ new OperatingSystem( 1, "Windows 7 (64 Bit)", null, "AMD64", 196608, 256 ),
+ new OperatingSystem( 2, "Windows 8 (32 Bit)", null, "x86", 4096, 32 ),
+ new OperatingSystem( 3, "Windows 8 (64 Bit)", null, "AMD64", 131072, 256 ),
+ new OperatingSystem( 4, "Ubuntu (32 Bit)", null, "x86", 0, 0 ),
+ new OperatingSystem( 5, "Ubuntu (64 Bit)", null, "AMD64", 0, 0 ),
+ new OperatingSystem( 6, "OpenSUSE (32 Bit)", null, "x86", 0, 0 ),
+ new OperatingSystem( 7, "OpenSUSE (64 Bit)", null, "AMD64", 0, 0 ),
+ new OperatingSystem( 8, "Other Linux (32 Bit)", null, "x86", 0, 0 ),
+ new OperatingSystem( 9, "Other Linux (64 Bit)", null, "AMD64", 0, 0 ),
+ new OperatingSystem( 10, "Windows 7 (32 Bit)", null, "x86", 4096, 32 ),
+ new OperatingSystem( 11, "Windows 2000 Professional", null, "x86", 4096, 4 ) ) );
+ // @formatter:on
+
+ private static final String REGEX_UUID = "[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}";
+
+ public static VirtualizationConfiguration<?, ?, ?, ?> newVirtualizationConfigurationInstance( File configFile )
+ {
+ VirtualizationConfiguration<?, ?, ?, ?> config = null;
+
+ try {
+ config = VirtualizationConfiguration.getInstance( ConfigurationLogicTestUtils.STUB_OS_LIST, configFile );
+ } catch ( IOException e ) {
+ fail( "Virtualization configuration file '" + configFile.getName() + "' can not be processed!" );
+ }
+
+ if ( config == null ) {
+ fail( "Virtualization configuration can not be created from file '" + configFile.getName() + "'" );
+ }
+
+ return config;
+ }
+
+ public static String readFileToString( File file )
+ {
+ String content = null;
+
+ try {
+ content = FileUtils.readFileToString( file, StandardCharsets.UTF_8 );
+ } catch ( IOException e ) {
+ fail( "Could not read content of file '" + file.getName() + "'" );
+ }
+
+ return content;
+ }
+
+ public static boolean isContentEqual( String content1, String content2 )
+ {
+ final BufferedReader bfrContent1 = new BufferedReader( new StringReader( content1 ) );
+ final BufferedReader bfrContent2 = new BufferedReader( new StringReader( content2 ) );
+ final List<String> linesContent1 = bfrContent1.lines().collect( Collectors.toList() );
+ final List<String> linesContent2 = bfrContent2.lines().collect( Collectors.toList() );
+
+ Collections.sort( linesContent1 );
+ Collections.sort( linesContent2 );
+
+ return linesContent1.equals( linesContent2 );
+ }
+
+ public static String removeUuid( String content )
+ {
+ final Pattern patternUuid = Pattern.compile( ConfigurationLogicTestUtils.REGEX_UUID );
+ final Matcher matcherUuidContent = patternUuid.matcher( content );
+
+ // replace all UUIDs with the empty String
+ return matcherUuidContent.replaceAll( "" );
+ }
+
+ public static boolean isVirtualBoxContentEqual( String content1, String content2 )
+ {
+ // replace all UUIDs with the empty String
+ final String filteredContent1 = ConfigurationLogicTestUtils.removeUuid( content1 );
+ final String filteredContent2 = ConfigurationLogicTestUtils.removeUuid( content2 );
+
+ return ConfigurationLogicTestUtils.isContentEqual( filteredContent1, filteredContent2 );
+ }
+}