diff options
Diffstat (limited to 'test/packaging/msi')
-rw-r--r-- | test/packaging/msi/file-placement.py | 172 | ||||
-rw-r--r-- | test/packaging/msi/package.py | 138 |
2 files changed, 310 insertions, 0 deletions
diff --git a/test/packaging/msi/file-placement.py b/test/packaging/msi/file-placement.py new file mode 100644 index 0000000..08b0ba6 --- /dev/null +++ b/test/packaging/msi/file-placement.py @@ -0,0 +1,172 @@ +#!/usr/bin/env python +# +# __COPYRIGHT__ +# +# Permission is hereby granted, free of charge, to any person obtaining +# a copy of this software and associated documentation files (the +# "Software"), to deal in the Software without restriction, including +# without limitation the rights to use, copy, modify, merge, publish, +# distribute, sublicense, and/or sell copies of the Software, and to +# permit persons to whom the Software is furnished to do so, subject to +# the following conditions: +# +# The above copyright notice and this permission notice shall be included +# in all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY +# KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE +# WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE +# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. +# + +__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__" + +""" +Test the msi packagers ability to put files into distinct directories. +""" + +import TestSCons + +python = TestSCons.python + +test = TestSCons.TestSCons() + +try: + from xml.dom.minidom import * +except ImportError: + test.skip_test('Canoot import xml.dom.minidom skipping test\n') + +wix = test.Environment().WhereIs('candle') + +if wix: + # + # Test the default directory layout + # + test.write( 'file1.exe', "file1" ) + + test.write('SConstruct', """ +env = Environment(tools=['default', 'packaging']) +f1 = env.Install( '/bin/' , 'file1.exe' ) + +env.Package( NAME = 'foo', + VERSION = '1.2', + PACKAGETYPE = 'msi', + SUMMARY = 'balalalalal', + DESCRIPTION = 'this should be reallly really long', + VENDOR = 'Nanosoft_2000', + source = [ f1 ], + ) +""") + + test.run(arguments='', stderr = None) + + dom = parse( test.workpath( 'foo-1.2.wxs' ) ) + dirs = dom.getElementsByTagName( 'Directory' ) + + test.fail_test( not dirs[0].attributes['Name'].value == 'SourceDir' ) + test.fail_test( not dirs[1].attributes['Name'].value == 'PFiles' ) + test.fail_test( not dirs[2].attributes['Name'].value == 'NANOSOF1' ) + test.fail_test( not dirs[3].attributes['Name'].value == 'FOO-1.2' ) + + # + # Try to put 7 files into 5 distinct directories of varying depth and overlapping count + # + test.write( 'file1.exe', "file1" ) + test.write( 'file2.exe', "file2" ) + test.write( 'file3.dll', "file3" ) + test.write( 'file4.dll', "file4" ) + test.write( 'file5.class', "file5" ) + test.write( 'file6.class', "file6" ) + test.write( 'file7.class', "file7" ) + + test.write('SConstruct', """ +env = Environment(tools=['default', 'packaging']) +f1 = env.Install( '/bin/' , 'file1.exe' ) +f2 = env.Install( '/bin/' , 'file2.exe' ) +f3 = env.Install( '/lib/' , 'file3.dll' ) +f4 = env.Install( '/lib/' , 'file4.dll' ) +f5 = env.Install( '/java/edu/teco/' , 'file5.class' ) +f6 = env.Install( '/java/teco/' , 'file6.class' ) +f7 = env.Install( '/java/tec/' , 'file7.class' ) + +env.Package( NAME = 'foo', + VERSION = '1.2', + PACKAGETYPE = 'msi', + SUMMARY = 'balalalalal', + DESCRIPTION = 'this should be reallly really long', + VENDOR = 'Nanosoft_2000', + LICENSE = 'afl', + source = [ f1, f2, f3, f4, f5, f6, f7 ], + ) +""") + + test.run(arguments='', stderr = None) + + dom = parse( test.workpath( 'foo-1.2.wxs' ) ) + files = dom.getElementsByTagName( 'File' ) + + test.fail_test( not files[0].parentNode.parentNode.attributes['LongName'].value == 'bin' ) + test.fail_test( not files[1].parentNode.parentNode.attributes['LongName'].value == 'bin' ) + test.fail_test( not files[2].parentNode.parentNode.attributes['LongName'].value == 'lib' ) + test.fail_test( not files[3].parentNode.parentNode.attributes['LongName'].value == 'lib' ) + + test.fail_test( not files[4].parentNode.parentNode.attributes['LongName'].value == 'teco' ) + test.fail_test( not files[4].parentNode.parentNode.parentNode.attributes['LongName'].value == 'edu' ) + test.fail_test( not files[4].parentNode.parentNode.parentNode.parentNode.attributes['LongName'].value == 'java' ) + + test.fail_test( not files[5].parentNode.parentNode.attributes['LongName'].value == 'teco' ) + test.fail_test( not files[5].parentNode.parentNode.parentNode.attributes['LongName'].value == 'java' ) + + test.fail_test( not files[6].parentNode.parentNode.attributes['LongName'].value == 'tec' ) + test.fail_test( not files[6].parentNode.parentNode.parentNode.attributes['LongName'].value == 'java' ) + + # + # Test distinct directories put into distinct features + # + test.write( 'file1.exe', "file1" ) + test.write( 'file2.exe', "file2" ) + test.write( 'file3.dll', "file3" ) + test.write( 'file3-.dll', "file3" ) + + test.write('SConstruct', """ +env = Environment(tools=['default', 'packaging']) +f1 = env.Install( '/bin/' , 'file1.exe' ) +f2 = env.Install( '/bin/' , 'file2.exe' ) +f3 = env.Install( '/lib/' , 'file3.dll' ) +f4 = env.Install( '/lib/' , 'file3-.dll' ) # generate a collision in the ids + +env.Tag( [f1, f2, f4], X_MSI_FEATURE = 'Core Part' ) +env.Tag( f3, X_MSI_FEATURE = 'Java Part' ) + +env.Package( NAME = 'foo', + VERSION = '1.2', + PACKAGETYPE = 'msi', + SUMMARY = 'balalalalal', + DESCRIPTION = 'this should be reallly really long', + VENDOR = 'Nanosoft_2000', + LICENSE = 'afl', + source = [ f1, f2, f3, f4 ], + ) +""") + + test.run(arguments='', stderr = None) + + dom = parse( test.workpath( 'foo-1.2.wxs' ) ) + features = dom.getElementsByTagName( 'Feature' ) + + test.fail_test( not features[1].attributes['Title'].value == 'Core Part' ) + componentrefs = features[1].getElementsByTagName( 'ComponentRef' ) + test.fail_test( not componentrefs[0].attributes['Id'].value == 'file1.exe' ) + test.fail_test( not componentrefs[1].attributes['Id'].value == 'file2.exe' ) + test.fail_test( not componentrefs[2].attributes['Id'].value == 'file3.dll1' ) + + test.fail_test( not features[2].attributes['Title'].value == 'Java Part' ) + componentrefs = features[2].getElementsByTagName( 'ComponentRef' ) + test.fail_test( not componentrefs[0].attributes['Id'].value == 'file3.dll' ) + +else: + test.no_result() + diff --git a/test/packaging/msi/package.py b/test/packaging/msi/package.py new file mode 100644 index 0000000..24bd26d --- /dev/null +++ b/test/packaging/msi/package.py @@ -0,0 +1,138 @@ +#!/usr/bin/env python +# +# __COPYRIGHT__ +# +# Permission is hereby granted, free of charge, to any person obtaining +# a copy of this software and associated documentation files (the +# "Software"), to deal in the Software without restriction, including +# without limitation the rights to use, copy, modify, merge, publish, +# distribute, sublicense, and/or sell copies of the Software, and to +# permit persons to whom the Software is furnished to do so, subject to +# the following conditions: +# +# The above copyright notice and this permission notice shall be included +# in all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY +# KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE +# WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE +# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. +# + +__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__" + +""" +Test the ability to create a simple msi package. +""" + +import os +import TestSCons + +python = TestSCons.python + +test = TestSCons.TestSCons() + +try: + from xml.dom.minidom import * +except ImportError: + test.skip_test('Canoot import xml.dom.minidom skipping test\n') + +wix = test.Environment().WhereIs('candle') + +if wix: + # + # build with minimal tag set and test for the given package meta-data + # + test.write( 'file1.exe', "file1" ) + test.write( 'file2.exe', "file2" ) + + test.write('SConstruct', """ +import os + +env = Environment(tools=['default', 'packaging']) + +f1 = env.Install( '/usr/' , 'file1.exe' ) +f2 = env.Install( '/usr/' , 'file2.exe' ) + +env.Package( NAME = 'foo', + VERSION = '1.2', + PACKAGETYPE = 'msi', + SUMMARY = 'balalalalal', + DESCRIPTION = 'this should be reallly really long', + VENDOR = 'Nanosoft_2000', + source = [ f1, f2 ], + ) + +env.Alias( 'install', [ f1, f2 ] ) +""") + + test.run(arguments='', stderr = None) + + test.must_exist( 'foo-1.2.wxs' ) + test.must_exist( 'foo-1.2.msi' ) + + dom = parse( test.workpath( 'foo-1.2.wxs' ) ) + Product = dom.getElementsByTagName( 'Product' )[0] + Package = dom.getElementsByTagName( 'Package' )[0] + + test.fail_test( not Product.attributes['Manufacturer'].value == 'Nanosoft_2000' ) + test.fail_test( not Product.attributes['Version'].value == '1.2' ) + test.fail_test( not Product.attributes['Name'].value == 'foo' ) + + test.fail_test( not Package.attributes['Description'].value == 'balalalalal' ) + test.fail_test( not Package.attributes['Comments'].value == 'this should be reallly really long' ) + + # + # build with file tags resulting in multiple components in the msi installer + # + test.write( 'file1.exe', "file1" ) + test.write( 'file2.exe', "file2" ) + test.write( 'file3.html', "file3" ) + test.write( 'file4.dll', "file4" ) + test.write( 'file5.dll', "file5" ) + + test.write('SConstruct', """ +import os +env = Environment(tools=['default', 'packaging']) +f1 = env.Install( '/usr/' , 'file1.exe' ) +f2 = env.Install( '/usr/' , 'file2.exe' ) +f3 = env.Install( '/usr/' , 'file3.html' ) +f4 = env.Install( '/usr/' , 'file4.dll' ) +f5 = env.Install( '/usr/' , 'file5.dll' ) + +env.Tag( f1, X_MSI_FEATURE = 'Java Part' ) +env.Tag( f2, X_MSI_FEATURE = 'Java Part' ) +env.Tag( f3, 'DOC' ) +env.Tag( f4, X_MSI_FEATURE = 'default' ) +env.Tag( f5, X_MSI_FEATURE = ('Another Feature', 'with a long description') ) + +env.Package( NAME = 'foo', + VERSION = '1.2', + PACKAGETYPE = 'msi', + SUMMARY = 'balalalalal', + DESCRIPTION = 'this should be reallly really long', + VENDOR = 'Nanosoft_tx2000', + source = [ f1, f2, f3, f4, f5 ], + ) + +env.Alias( 'install', [ f1, f2, f3, f4, f5 ] ) +""") + + test.run(arguments='', stderr = None) + + test.must_exist( 'foo-1.2.wxs' ) + test.must_exist( 'foo-1.2.msi' ) + + dom = parse( test.workpath( 'foo-1.2.wxs' ) ) + elements = dom.getElementsByTagName( 'Feature' ) + test.fail_test( not elements[1].attributes['Title'].value == 'Main Part' ) + test.fail_test( not elements[2].attributes['Title'].value == 'Documentation' ) + test.fail_test( not elements[3].attributes['Title'].value == 'Another Feature' ) + test.fail_test( not elements[3].attributes['Description'].value == 'with a long description' ) + test.fail_test( not elements[4].attributes['Title'].value == 'Java Part' ) + +else: + test.no_result() |