Skip to content


Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
tree: 3f6231502a
Fetching contributors…

Cannot retrieve contributors at this time

196 lines (156 sloc) 6.477 kb
import sys
from validator.submain import populate_chrome_manifest
from validator.rdf import RDFParser
from validator.xpi import XPIManager
from validator.errorbundler import ErrorBundle
from validator.outputhandlers.shellcolors import OutputHandler
import validator.testcases.regex as regex
def _do_test(path, test, failure=True,
require_install=False, set_type=0,
listed=False, xpi_mode="r"):
package_data = open(path, "rb")
package = XPIManager(package_data, mode=xpi_mode, name=path)
err = ErrorBundle()
if listed:
err.save_resource("listed", True)
# Populate in the dependencies.
if set_type:
err.set_type(set_type) # Conduit test requires type
if require_install:
err.save_resource("has_install_rdf", True)
rdf_data ="install.rdf")
install_rdf = RDFParser(err, rdf_data)
err.save_resource("install_rdf", install_rdf)
populate_chrome_manifest(err, package)
test(err, package)
print err.print_summary(verbose=True)
if failure:
assert err.failed()
assert not err.failed()
return err
class TestCase(object):
def setUp(self):
self.err = None
self.is_jetpack = False
self.is_bootstrapped = False
self.detected_type = None
self.listed = True
def reset(self):
Reset the test case so that it can be run a second time (ideally with
different parameters).
self.err = None
def setup_err(self, for_appversions=None):
Instantiate the error bundle object. Use the `instant` parameter to
have it output errors as they're generated. `for_appversions` may be set
to target the test cases at a specific Gecko version range.
An existing error bundle will be overwritten with a fresh one that has
the state that the test case was setup with.
self.err = ErrorBundle(instant=True,
for_appversions=for_appversions or {},
self.err.handler = OutputHandler(sys.stdout, True)
if self.is_jetpack:
self.err.metadata["is_jetpack"] = True
if self.is_bootstrapped:
self.err.save_resource("em:bootstrap", True)
if self.detected_type is not None:
self.err.detected_Type = self.detected_type
def assert_failed(self, with_errors=False, with_warnings=None):
First, asserts that the error bundle registers a failure (recognizing
whether warnings are acknowledged). Second, if with_errors is True,
the presence of errors is asserted. If it is not true (default), it
is tested that errors are not present. If with_warnings is not None,
the presence of warnings is tested just like with_errors)
assert self.err.failed(
fail_on_warnings=with_warnings or with_warnings is None), \
"Test did not fail; failure was expected."
if with_errors:
assert self.err.errors, "Errors were expected."
elif self.err.errors:
raise AssertionError("Tests found unexpected errors: %s" %
if with_warnings is not None:
if with_warnings:
assert self.err.warnings, "Warnings were expected."
elif self.err.warnings:
raise ("Tests found unexpected warnings: %s" %
def assert_notices(self):
Assert that notices have been generated during the validation process.
assert self.err.notices, "Notices were expected."
def assert_passes(self, warnings_pass=False):
Assert that no errors have been raised. If warnings_pass is True, also
assert that there are no warnings.
assert not self.failed(fail_on_warnings=not warnings_pass), \
("Test was intended to pass%s, but it did not." %
(" with warnings" if warnings_pass else ""))
def assert_silent(self):
Assert that no messages (errors, warnings, or notices) have been
assert not self.err.errors, 'Got these: %s' % self.err.errors
assert not self.err.warnings, 'Got these: %s' % self.err.warnings
assert not self.err.notices, 'Got these: %s' % self.err.notices
assert not any(self.err.compat_summary.values()), \
"Found compatibility messages."
def assert_got_errid(self, errid):
Assert that a message with the given errid has been generated during
the validation process.
assert any(msg["id"] == errid for msg in
(self.err.errors + self.err.warnings + self.err.notices)), \
"%s was expected, but it was not found." % repr(errid)
class RegexTestCase(TestCase):
A helper class to provide functions useful for performing tests against
regex test scenarios.
def run_regex(self, input):
"""Run the standard regex tests for non-JavaScript input."""
if self.err is None:
input = '<input onclick="%s" />' % input
regex.run_regex_tests(input, self.err, "foo.txt", is_js=False)
def run_js_regex(self, input):
"""Run the standard regex tests for JavaScript input."""
if self.err is None:
regex.run_regex_tests(input, self.err, "foo.txt", is_js=True)
class MockZipFile:
def namelist(self):
return []
class MockXPI:
def __init__(self, data=None, subpackage=False):
if not data:
data = {}
self.zf = MockZipFile() = data
self.subpackage = subpackage
self.filename = "mock_xpi.xpi"
def test(self):
return True
def info(self, name):
return {"name_lower": name.lower(),
"extension": name.lower().split(".")[-1]}
def __iter__(self):
def i():
for name in
yield name
return i()
def __contains__(self, name):
return name in
def read(self, name):
return open([name]).read()
Jump to Line
Something went wrong with that request. Please try again.