32 TEST_VARIANT_CPF = os.path.join(TESTDATA_DIR, 'variant.cpf') |
32 TEST_VARIANT_CPF = os.path.join(TESTDATA_DIR, 'variant.cpf') |
33 |
33 |
34 |
34 |
35 class TestInitVariant(BaseTestCase): |
35 class TestInitVariant(BaseTestCase): |
36 |
36 |
37 def _prepare_workdir(self, subdir, expected_zip): |
37 def _prepare_workdir(self, subdir, project_zip, expected_zip): |
38 WORKDIR = os.path.join(TEMP_DIR, subdir) |
38 WORKDIR = os.path.join(TEMP_DIR, subdir) |
39 PROJECT_DIR = os.path.join(WORKDIR, 'project') |
39 PROJECT_DIR = os.path.join(WORKDIR, 'project') |
40 EXPECTED_DIR = os.path.join(WORKDIR, 'expected') |
40 EXPECTED_DIR = os.path.join(WORKDIR, 'expected') |
41 |
41 |
42 self.remove_if_exists(WORKDIR) |
42 self.remove_if_exists(WORKDIR) |
43 |
43 |
44 unzip_file.unzip_file( |
44 unzip_file.unzip_file( |
45 os.path.join(TESTDATA_DIR, 'test_project.zip'), |
45 os.path.join(TESTDATA_DIR, project_zip), |
46 PROJECT_DIR) |
46 PROJECT_DIR) |
47 unzip_file.unzip_file( |
47 unzip_file.unzip_file( |
48 os.path.join(TESTDATA_DIR, expected_zip), |
48 os.path.join(TESTDATA_DIR, expected_zip), |
49 EXPECTED_DIR) |
49 EXPECTED_DIR) |
50 |
50 |
55 p = api.Project(api.Storage.open(project, 'r')) |
55 p = api.Project(api.Storage.open(project, 'r')) |
56 active_root = p.get_storage().get_active_configuration() |
56 active_root = p.get_storage().get_active_configuration() |
57 p.close() |
57 p.close() |
58 return active_root |
58 return active_root |
59 |
59 |
60 def test_initvariant(self): |
60 def test_initvariant_set_active_root(self): |
61 PROJECT_DIR, EXPECTED_DIR = self._prepare_workdir('var1', 'expected.zip') |
61 PROJECT_DIR, EXPECTED_DIR = self._prepare_workdir('var1', 'test_project.zip', 'expected.zip') |
62 |
62 |
63 self.assertEquals(self._get_active_configuration(PROJECT_DIR), None) |
63 self.assertEquals(self._get_active_configuration(PROJECT_DIR), None) |
64 |
64 |
65 cmd = '%s -p "%s" -r "%s" --variant-id 123 --variant-name foo --set-active-root' % (get_cmd('initvariant'), PROJECT_DIR, TEST_VARIANT_CPF) |
65 cmd = '%s -p "%s" -r "%s" --variant-id 123 --variant-name foo --set-active-root' % (get_cmd('initvariant'), PROJECT_DIR, TEST_VARIANT_CPF) |
66 self.run_command(cmd) |
66 self.run_command(cmd) |
68 self.assert_dir_contents_equal(PROJECT_DIR, EXPECTED_DIR, ['.svn', '.metadata']) |
68 self.assert_dir_contents_equal(PROJECT_DIR, EXPECTED_DIR, ['.svn', '.metadata']) |
69 self.assertEquals(self._get_active_configuration(PROJECT_DIR), |
69 self.assertEquals(self._get_active_configuration(PROJECT_DIR), |
70 'testprod_custvariant_123_foo_root.confml') |
70 'testprod_custvariant_123_foo_root.confml') |
71 |
71 |
72 |
72 |
73 def test_initvariant_2(self): |
73 def test_initvariant_do_not_set_active_root(self): |
74 PROJECT_DIR, EXPECTED_DIR = self._prepare_workdir('var2', 'expected2.zip') |
74 PROJECT_DIR, EXPECTED_DIR = self._prepare_workdir('var2', 'test_project.zip', 'expected2.zip') |
75 |
75 |
76 self.assertEquals(self._get_active_configuration(PROJECT_DIR), None) |
76 self.assertEquals(self._get_active_configuration(PROJECT_DIR), None) |
77 |
77 |
78 cmd = '%s -p "%s" -r "%s" -c foovariant.confml --variant-id 321' % (get_cmd('initvariant'), PROJECT_DIR, TEST_VARIANT_CPF) |
78 cmd = '%s -p "%s" -r "%s" -c foovariant.confml --variant-id 321' % (get_cmd('initvariant'), PROJECT_DIR, TEST_VARIANT_CPF) |
79 self.run_command(cmd) |
79 self.run_command(cmd) |
81 self.assert_dir_contents_equal(PROJECT_DIR, EXPECTED_DIR, ['.svn', '.metadata']) |
81 self.assert_dir_contents_equal(PROJECT_DIR, EXPECTED_DIR, ['.svn', '.metadata']) |
82 self.assertEquals(self._get_active_configuration(PROJECT_DIR), None) |
82 self.assertEquals(self._get_active_configuration(PROJECT_DIR), None) |
83 |
83 |
84 |
84 |
85 def test_initvariant_based_on_configuration(self): |
85 def test_initvariant_based_on_configuration(self): |
86 PROJECT_DIR, EXPECTED_DIR = self._prepare_workdir('var3', 'expected3.zip') |
86 PROJECT_DIR, EXPECTED_DIR = self._prepare_workdir('var3', 'test_project.zip', 'expected3.zip') |
87 |
87 |
88 self.assertEquals(self._get_active_configuration(PROJECT_DIR), None) |
88 self.assertEquals(self._get_active_configuration(PROJECT_DIR), None) |
89 |
89 |
90 cmd = '%s -p "%s" -c foovariant.confml --variant-id=123 -b testprod_custvariant_root.confml' % (get_cmd('initvariant'), PROJECT_DIR) |
90 cmd = '%s -p "%s" -c foovariant.confml --variant-id=123 -b testprod_custvariant_root.confml' % (get_cmd('initvariant'), PROJECT_DIR) |
91 |
91 self.run_command(cmd) |
|
92 |
|
93 self.assert_dir_contents_equal(PROJECT_DIR, EXPECTED_DIR, ['.svn', '.metadata']) |
|
94 self.assertEquals(self._get_active_configuration(PROJECT_DIR), None) |
|
95 |
|
96 def test_initvariant_based_on_configuration_on_dcp_structure(self): |
|
97 # variant dir is project/product/customer/variant instead of project/coreplat/product/customer/variant |
|
98 PROJECT_DIR, EXPECTED_DIR = self._prepare_workdir('var4', 'project4.zip', 'expected4.zip') |
|
99 |
|
100 cmd = '%s -p "%s" -c foovariant.confml --variant-id=123 -b testprod_custvariant_root.confml' % (get_cmd('initvariant'), PROJECT_DIR) |
|
101 self.run_command(cmd) |
|
102 |
|
103 self.assert_dir_contents_equal(PROJECT_DIR, EXPECTED_DIR, ['.svn', '.metadata']) |
|
104 self.assertEquals(self._get_active_configuration(PROJECT_DIR), None) |
|
105 |
|
106 # test that when root config in cpf has multiple ctr codes defined and a matching updated |
|
107 # root config with all the same ctr codes is found, the target root config is created |
|
108 # accordingly |
|
109 def test_initvariant_with_updated_root_in_target_project(self): |
|
110 PROJECT_DIR, EXPECTED_DIR = self._prepare_workdir('var5', 'test_project2.zip', 'expected5.zip') |
|
111 TEST_CPF = os.path.join(TESTDATA_DIR, 'test_project.cpf') |
|
112 ROOT_CONFIG = 'testprod_custvariant_03_root.confml' |
|
113 FIND_LAYER_REGEXP = r'.*custvar[^/].*|.*/configurator/.*|.*/manual/.*' |
|
114 |
|
115 cmd = '%s -p "%s" -s %s -c foovariant.confml --variant-id=123 -r %s --find-layer-regexp=\"%s\"' % (get_cmd('initvariant'), PROJECT_DIR, ROOT_CONFIG, TEST_CPF, FIND_LAYER_REGEXP) |
|
116 self.run_command(cmd) |
|
117 |
|
118 self.assert_dir_contents_equal(PROJECT_DIR, EXPECTED_DIR, ['.svn', '.metadata']) |
|
119 self.assertEquals(self._get_active_configuration(PROJECT_DIR), None) |
|
120 |
|
121 # test that when root config in cpf has ONE ctr code defined, a matching updated root config is |
|
122 # found from target project and the target root config is created accordingly |
|
123 def test_initvariant_with_one_matching_ctr_code(self): |
|
124 PROJECT_DIR, EXPECTED_DIR = self._prepare_workdir('var6', 'test_project2.zip', 'expected6.zip') |
|
125 TEST_CPF = os.path.join(TESTDATA_DIR, 'test_project.cpf') |
|
126 ROOT_CONFIG = 'testprod_custvariant_04_root.confml' |
|
127 FIND_LAYER_REGEXP = r'.*custvar[^/].*|.*/configurator/.*|.*/manual/.*' |
|
128 |
|
129 cmd = '%s -p "%s" -s %s -c foovariant.confml --variant-id=123 -r %s --find-layer-regexp=\"%s\"' % (get_cmd('initvariant'), PROJECT_DIR, ROOT_CONFIG, TEST_CPF, FIND_LAYER_REGEXP) |
92 self.run_command(cmd) |
130 self.run_command(cmd) |
93 |
131 |
94 self.assert_dir_contents_equal(PROJECT_DIR, EXPECTED_DIR, ['.svn', '.metadata']) |
132 self.assert_dir_contents_equal(PROJECT_DIR, EXPECTED_DIR, ['.svn', '.metadata']) |
95 self.assertEquals(self._get_active_configuration(PROJECT_DIR), None) |
133 self.assertEquals(self._get_active_configuration(PROJECT_DIR), None) |
96 |
134 |
97 |
|
98 if __name__ == '__main__': |
135 if __name__ == '__main__': |
99 unittest.main() |
136 unittest.main() |