summaryrefslogtreecommitdiffstats
path: root/testing/mozbase/mozinfo/tests
diff options
context:
space:
mode:
authorMatt A. Tobin <mattatobin@localhost.localdomain>2018-02-02 04:16:08 -0500
committerMatt A. Tobin <mattatobin@localhost.localdomain>2018-02-02 04:16:08 -0500
commit5f8de423f190bbb79a62f804151bc24824fa32d8 (patch)
tree10027f336435511475e392454359edea8e25895d /testing/mozbase/mozinfo/tests
parent49ee0794b5d912db1f95dce6eb52d781dc210db5 (diff)
downloadUXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar
UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.gz
UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.lz
UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.xz
UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.zip
Add m-esr52 at 52.6.0
Diffstat (limited to 'testing/mozbase/mozinfo/tests')
-rw-r--r--testing/mozbase/mozinfo/tests/manifest.ini1
-rw-r--r--testing/mozbase/mozinfo/tests/test.py121
2 files changed, 122 insertions, 0 deletions
diff --git a/testing/mozbase/mozinfo/tests/manifest.ini b/testing/mozbase/mozinfo/tests/manifest.ini
new file mode 100644
index 000000000..528fdea7b
--- /dev/null
+++ b/testing/mozbase/mozinfo/tests/manifest.ini
@@ -0,0 +1 @@
+[test.py]
diff --git a/testing/mozbase/mozinfo/tests/test.py b/testing/mozbase/mozinfo/tests/test.py
new file mode 100644
index 000000000..b9457cff9
--- /dev/null
+++ b/testing/mozbase/mozinfo/tests/test.py
@@ -0,0 +1,121 @@
+#!/usr/bin/env python
+#
+# This Source Code Form is subject to the terms of the Mozilla Public
+# 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 json
+import mock
+import os
+import shutil
+import sys
+import tempfile
+import unittest
+import mozinfo
+
+
+class TestMozinfo(unittest.TestCase):
+
+ def setUp(self):
+ reload(mozinfo)
+ self.tempdir = os.path.abspath(tempfile.mkdtemp())
+
+ # When running from an objdir mozinfo will use a build generated json file
+ # instead of the ones created for testing. Prevent that from happening.
+ # See bug 896038 for details.
+ sys.modules['mozbuild'] = None
+
+ def tearDown(self):
+ shutil.rmtree(self.tempdir)
+ del sys.modules['mozbuild']
+
+ def test_basic(self):
+ """Test that mozinfo has a few attributes."""
+ self.assertNotEqual(mozinfo.os, None)
+ # should have isFoo == True where os == "foo"
+ self.assertTrue(getattr(mozinfo, "is" + mozinfo.os[0].upper() + mozinfo.os[1:]))
+
+ def test_update(self):
+ """Test that mozinfo.update works."""
+ mozinfo.update({"foo": 123})
+ self.assertEqual(mozinfo.info["foo"], 123)
+
+ def test_update_file(self):
+ """Test that mozinfo.update can load a JSON file."""
+ j = os.path.join(self.tempdir, "mozinfo.json")
+ with open(j, "w") as f:
+ f.write(json.dumps({"foo": "xyz"}))
+ mozinfo.update(j)
+ self.assertEqual(mozinfo.info["foo"], "xyz")
+
+ def test_update_file_invalid_json(self):
+ """Test that mozinfo.update handles invalid JSON correctly"""
+ j = os.path.join(self.tempdir, 'test.json')
+ with open(j, 'w') as f:
+ f.write('invalid{"json":')
+ self.assertRaises(ValueError, mozinfo.update, [j])
+
+ def test_find_and_update_file(self):
+ """Test that mozinfo.find_and_update_from_json can
+ find mozinfo.json in a directory passed to it."""
+ j = os.path.join(self.tempdir, "mozinfo.json")
+ with open(j, "w") as f:
+ f.write(json.dumps({"foo": "abcdefg"}))
+ self.assertEqual(mozinfo.find_and_update_from_json(self.tempdir), j)
+ self.assertEqual(mozinfo.info["foo"], "abcdefg")
+
+ def test_find_and_update_file_invalid_json(self):
+ """Test that mozinfo.find_and_update_from_json can
+ handle invalid JSON"""
+ j = os.path.join(self.tempdir, "mozinfo.json")
+ with open(j, 'w') as f:
+ f.write('invalid{"json":')
+ self.assertRaises(ValueError, mozinfo.find_and_update_from_json, self.tempdir)
+
+ def test_find_and_update_file_mozbuild(self):
+ """Test that mozinfo.find_and_update_from_json can
+ find mozinfo.json using the mozbuild module."""
+ j = os.path.join(self.tempdir, "mozinfo.json")
+ with open(j, "w") as f:
+ f.write(json.dumps({"foo": "123456"}))
+ m = mock.MagicMock()
+ # Mock the value of MozbuildObject.from_environment().topobjdir.
+ m.MozbuildObject.from_environment.return_value.topobjdir = self.tempdir
+ with mock.patch.dict(sys.modules, {"mozbuild": m, "mozbuild.base": m}):
+ self.assertEqual(mozinfo.find_and_update_from_json(), j)
+ self.assertEqual(mozinfo.info["foo"], "123456")
+
+ def test_output_to_file(self):
+ """Test that mozinfo.output_to_file works."""
+ path = os.path.join(self.tempdir, "mozinfo.json")
+ mozinfo.output_to_file(path)
+ self.assertEqual(open(path).read(), json.dumps(mozinfo.info))
+
+
+class TestStringVersion(unittest.TestCase):
+
+ def test_os_version_is_a_StringVersion(self):
+ self.assertIsInstance(mozinfo.os_version, mozinfo.StringVersion)
+
+ def test_compare_to_string(self):
+ version = mozinfo.StringVersion('10.10')
+
+ self.assertGreater(version, '10.2')
+ self.assertGreater('11', version)
+ self.assertGreaterEqual(version, '10.10')
+ self.assertGreaterEqual('10.11', version)
+ self.assertEqual(version, '10.10')
+ self.assertEqual('10.10', version)
+ self.assertNotEqual(version, '10.2')
+ self.assertNotEqual('11', version)
+ self.assertLess(version, '11.8.5')
+ self.assertLess('10.2', version)
+ self.assertLessEqual(version, '11')
+ self.assertLessEqual('10.10', version)
+
+ def test_to_string(self):
+ self.assertEqual('10.10', str(mozinfo.StringVersion('10.10')))
+
+
+if __name__ == '__main__':
+ unittest.main()