| Index: tests/test_packagerEdge.py |
| diff --git a/tests/test_packagerEdge.py b/tests/test_packagerEdge.py |
| index 3eedfad5a68a4ae0891d5d126e58f0002971aa57..cc4f05fc4a2c600f83594bdd7bd3d67fc84f3e30 100644 |
| --- a/tests/test_packagerEdge.py |
| +++ b/tests/test_packagerEdge.py |
| @@ -2,63 +2,24 @@ |
| # License, v. 2.0. If a copy of the MPL was not distributed with this |
| # file, You can obtain one at http://mozilla.org/MPL/2.0/. |
| -import ConfigParser |
| -import json |
| import os |
| -import shutil |
| +import io |
| + |
| import xml.etree.ElementTree as ET |
| import zipfile |
| import pytest |
| from buildtools import packager, packagerEdge |
| - |
| -TEST_DIR = os.path.dirname(__file__) |
| -TEST_METADATA = os.path.join(TEST_DIR, 'metadata.edge') |
| -CHARS = b''.join(chr(i % 200 + 30) for i in range(500)) |
| -MESSAGES_EN_US = json.dumps({ |
| - 'name': {'message': 'Adblock Plus'}, |
| - 'name_devbuild': {'message': 'devbuild-marker'}, |
| - 'description': { |
| - 'message': 'Adblock Plus is the most popular ad blocker ever, ' |
| - 'and also supports websites by not blocking ' |
| - 'unobstrusive ads by default (configurable).' |
| - }, |
| -}) |
| +from buildtools.tests.tools import copy_metadata |
| @pytest.fixture |
| -def metadata(): |
| - """Loaded metadata config.""" |
| - conf_parser = ConfigParser.ConfigParser() |
| - conf_parser.read(TEST_METADATA) |
| - return conf_parser |
| +def edge_metadata(tmpdir): |
| + filename = 'metadata.edge' |
| + copy_metadata(filename, tmpdir) |
| - |
| -@pytest.fixture |
| -def files(): |
| - """Minimal Files() for testing manifest and blockmap.""" |
| - files = packager.Files(set(), set()) |
| - for size in ['44', '50', '150']: |
| - files['Assets/logo_{}.png'.format(size)] = CHARS |
| - files['Extension/_locales/en_US/messages.json'] = MESSAGES_EN_US |
| - files['Extension/foo.xml'] = CHARS |
| - files['Extension/bar.png'] = CHARS * 200 |
| - return files |
| - |
| - |
| -@pytest.fixture |
| -def srcdir(tmpdir): |
| - """Source directory for building the package.""" |
| - srcdir = tmpdir.mkdir('src') |
| - shutil.copy(TEST_METADATA, str(srcdir.join('metadata.edge'))) |
| - for size in ['44', '50', '150']: |
| - path = srcdir.join('chrome', 'icons', 'abp-{}.png'.format(size)) |
| - path.write(size, ensure=True) |
| - localedir = srcdir.mkdir('_locales') |
| - en_us_dir = localedir.mkdir('en_US') |
| - en_us_dir.join('messages.json').write(MESSAGES_EN_US) |
| - return srcdir |
| + return packager.readMetadata(str(tmpdir), 'edge') |
| def blockmap2dict(xml_data): |
| @@ -73,8 +34,8 @@ def blockmap2dict(xml_data): |
| } |
| -def test_create_appx_blockmap(files): |
| - blockmap = blockmap2dict(packagerEdge.create_appx_blockmap(files)) |
| +def test_create_appx_blockmap(base_files): |
| + blockmap = blockmap2dict(packagerEdge.create_appx_blockmap(base_files)) |
| assert blockmap['Extension\\foo.xml'] == { |
| 'size': '500', |
| 'lfhsize': '47', |
| @@ -129,106 +90,32 @@ def test_full_content_types_map(): |
| } |
| -def test_create_appx_manifest(metadata, files): |
| - namespaces = { |
| - 'ns': 'http://schemas.microsoft.com/' |
| - 'appx/manifest/foundation/windows10', |
| - 'uap': 'http://schemas.microsoft.com/appx/manifest/uap/windows10', |
| - 'uap3': 'http://schemas.microsoft.com/appx/manifest/uap/windows10/3', |
| - } |
| - |
| - def first(elem): |
| - return elem[0] |
| - |
| - def text(elem): |
| - return elem.text |
| - |
| - def attr(attr): |
| - def wrapper(elem): |
| - return elem.attrib[attr] |
| - return wrapper |
| - |
| - base = [ |
| - ('.//*', [len], 21.0), |
| - ('./ns:Identity', [first, attr('Publisher')], |
| - 'CN=4F066043-8AFE-41C9-B762-6C15E77E3F88'), |
| - ('./ns:Identity', [first, attr('Version')], '1.2.3.0'), |
| - ('./ns:Properties/ns:PublisherDisplayName', [first, text], |
| - 'Eyeo GmbH'), |
| - ('./ns:Properties/ns:Logo', [first, text], 'Assets\\logo_50.png'), |
| - ('./ns:Dependencies/ns:TargetDeviceFamily', |
| - [first, attr('MinVersion')], |
| - '10.0.14332.0'), |
| - ('./ns:Dependencies/ns:TargetDeviceFamily', |
| - [first, attr('MaxVersionTested')], |
| - '12.0.0.0'), |
| - ('./ns:Applications/ns:Application/uap:VisualElements', |
| - [first, attr('Square150x150Logo')], |
| - 'Assets\\logo_150.png'), |
| - ('./ns:Applications/ns:Application/uap:VisualElements', |
| - [first, attr('Square44x44Logo')], |
| - 'Assets\\logo_44.png'), |
| - ('./ns:Applications/ns:Application/uap:VisualElements', |
| - [first, attr('Description')], |
| - 'Adblock Plus is the most popular ad blocker ever, and also ' |
| - 'supports websites by not blocking unobstrusive ads by ' |
| - 'default (configurable).'), |
| - ('./ns:Applications/ns:Application/uap:VisualElements', |
| - [first, attr('BackgroundColor')], |
| - 'red'), |
| - ] |
| +@pytest.mark.parametrize('release_build', [True, False]) |
| +def test_create_appx_manifest(base_files, srcdir, release_build, |
| + edge_metadata): |
| + manifest = ET.fromstring(packagerEdge.create_appx_manifest( |
| + {'metadata': edge_metadata}, |
| + base_files, |
| + release_build=release_build)) |
| - devbuild = base + [ |
| - ('./ns:Identity', [first, attr('Name')], |
| - 'EyeoGmbH.AdblockPlusdevelopmentbuild'), |
| - ('./ns:Properties/ns:DisplayName', [first, text], 'devbuild-marker'), |
| - ('./ns:Applications/ns:Application/uap:VisualElements', |
| - [first, attr('DisplayName')], |
| - 'devbuild-marker'), |
| - ('./ns:Applications/ns:Application/ns:Extensions/uap3:Extension/' |
| - 'uap3:AppExtension', |
| - [first, attr('Id')], |
| - 'EdgeExtension'), |
| - ('./ns:Applications/ns:Application/ns:Extensions/uap3:Extension/' |
| - 'uap3:AppExtension', |
| - [first, attr('DisplayName')], |
| - 'devbuild-marker'), |
| - ] |
| + xmlpath = os.path.join( |
| + os.path.dirname(__file__), |
| + 'expecteddata', |
| + 'manifest_edge_{}.xml'.format(release_build) |
| + ) |
| - release = base + [ |
| - ('./ns:Identity', [first, attr('Name')], 'EyeoGmbH.AdblockPlus'), |
| - ('./ns:Properties/ns:DisplayName', [first, text], 'Adblock Plus'), |
| - ('./ns:Applications/ns:Application/uap:VisualElements', |
| - [first, attr('DisplayName')], |
| - 'Adblock Plus'), |
| - ('./ns:Applications/ns:Application/ns:Extensions/uap3:Extension/' |
| - 'uap3:AppExtension', |
| - [first, attr('Id')], |
| - '1.0'), |
| - ('./ns:Applications/ns:Application/ns:Extensions/uap3:Extension/' |
| - 'uap3:AppExtension', |
| - [first, attr('DisplayName')], |
| - 'Adblock Plus'), |
| - ] |
| + with io.open(xmlpath, 'r') as fp: |
| + expected = ET.fromstring(fp.read()) |
| - for release_build, pairs in [(False, devbuild), (True, release)]: |
| - manifest = ET.fromstring(packagerEdge.create_appx_manifest( |
| - {'metadata': metadata}, |
| - files, |
| - release_build=release_build)) |
| - for expression, modifiers, value in pairs: |
| - res = reduce( |
| - lambda val, func: func(val), |
| - modifiers, |
| - manifest.findall(expression, namespaces=namespaces)) |
| - assert res == value |
| + from buildtools.tests.tools import get_leafs_string |
| + assert set(get_leafs_string(expected)) == set(get_leafs_string(manifest)) |
| -def test_move_files_to_extension(): |
| +def test_move_files_to_extension(str500chars): |
| files = packager.Files(set(), set()) |
| - files['foo.xml'] = CHARS |
| - files['foo/bar.xml'] = CHARS |
| - files['Extension/foo.xml'] = CHARS |
| + files['foo.xml'] = str500chars |
| + files['foo/bar.xml'] = str500chars |
| + files['Extension/foo.xml'] = str500chars |
| packagerEdge.move_files_to_extension(files) |
| assert set(files.keys()) == { |
| 'Extension/foo.xml', |
| @@ -237,6 +124,7 @@ def test_move_files_to_extension(): |
| } |
| +@pytest.mark.usefixtures('edge_metadata') |
| def test_create_build(tmpdir, srcdir): |
| out_file = str(tmpdir.join('abp.appx')) |
| packagerEdge.createBuild(str(srcdir), outFile=out_file, releaseBuild=True) |
| @@ -252,6 +140,7 @@ def test_create_build(tmpdir, srcdir): |
| assert appx.read('Extension/icons/abp-44.png') == '44' |
| +@pytest.mark.usefixtures('edge_metadata') |
| def test_create_devbuild(tmpdir, srcdir): |
| out_file = str(tmpdir.join('abp.appx')) |
| packagerEdge.createBuild(str(srcdir), outFile=out_file, releaseBuild=False) |