public inbox for gentoo-commits@lists.gentoo.org
 help / color / mirror / Atom feed
From: "Jauhien Piatlicki" <piatlicki@gmail.com>
To: gentoo-commits@lists.gentoo.org
Subject: [gentoo-commits] proj/g-sorcery:master commit in: tests/
Date: Wed, 18 Sep 2013 00:57:23 +0000 (UTC)	[thread overview]
Message-ID: <1379465832.b3e47360bd5ccb871e0860c24220259d4fbb3da0.jauhien@gentoo> (raw)

commit:     b3e47360bd5ccb871e0860c24220259d4fbb3da0
Author:     Jauhien Piatlicki (jauhien) <piatlicki <AT> gmail <DOT> com>
AuthorDate: Wed Sep 18 00:57:12 2013 +0000
Commit:     Jauhien Piatlicki <piatlicki <AT> gmail <DOT> com>
CommitDate: Wed Sep 18 00:57:12 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/g-sorcery.git;a=commit;h=b3e47360

tests/test_DBGenerator: initial commit

---
 tests/test_DBGenerator.py | 110 ++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 110 insertions(+)

diff --git a/tests/test_DBGenerator.py b/tests/test_DBGenerator.py
new file mode 100644
index 0000000..b5e40f8
--- /dev/null
+++ b/tests/test_DBGenerator.py
@@ -0,0 +1,110 @@
+#!/usr/bin/env python
+# -*- coding: utf-8 -*-
+
+"""
+    test_DBGenerator.py
+    ~~~~~~~~~~~~~~~~~~~
+    
+    DBGenerator test suite
+    
+    :copyright: (c) 2013 by Jauhien Piatlicki
+    :license: GPL-2, see LICENSE for more details.
+"""
+
+import os
+import unittest
+
+from g_sorcery.compatibility import TemporaryDirectory
+from g_sorcery.exceptions import InvalidKeyError
+from g_sorcery.g_collections import Package
+from g_sorcery.package_db import DBGenerator
+
+from tests.base import BaseTest
+from tests.server import Server
+
+
+class TestingDBGenerator(DBGenerator):
+    def get_download_uries(self, common_config, config):
+        return [config["repo_uri"] + "/repo.data"]
+
+    def parse_data(self, data_f):
+        content = data_f.read()
+        content = content.split("packages\n")
+        ebuild_data_lines = content[0].split("\n")
+        packages_lines = content[1].split("\n")
+        ebuild_data = {}
+        packages = []
+        for line in ebuild_data_lines:
+            if line:
+                data = line.split(" ")
+                ebuild_data[data[0]] = data[1]
+        for line in packages_lines:
+            if line:
+                data = line.split(" ")
+                packages.append(Package(data[0], data[1], data[2]))
+        return {"ebuild_data": ebuild_data, "packages": packages}
+
+
+    def process_data(self, pkg_db, data, common_config, config):
+        data = data["repo.data"]
+        ebuild_data = data["ebuild_data"]
+        for package in data["packages"]:
+            pkg_db.add_category(package.category)
+            pkg_db.add_package(package, ebuild_data)
+
+
+class TestDBGenerator(BaseTest):
+
+    def test_functionality(self):
+        db_generator = TestingDBGenerator()
+        common_config = {}
+        config = {"repo_uri": "127.0.0.1:8080"}
+
+        packages = [Package("app-test1", "test", "1"), Package("app-test1", "test", "2"),
+                    Package("app-test1", "test1", "1"), Package("app-test2", "test2", "1")]
+        ebuild_data = {"test1": "test1", "test2": "test2"}
+
+        orig_tempdir = TemporaryDirectory()
+        with open(os.path.join(orig_tempdir.name, "repo.data"), "w") as f:
+            for key, value in ebuild_data.items():
+                f.write(key + " " + value + "\n")
+            f.write("packages\n")
+            for package in packages:
+                f.write(package.category + " " +  package.name + " " + package.version + "\n")
+
+        srv = Server(orig_tempdir.name)
+        srv.start()
+
+        pkg_db = db_generator(self.tempdir.name, "test_repo",
+                              common_config = common_config, config = config)
+
+        srv.shutdown()
+        srv.join()
+
+        self.assertEqual(set(pkg_db.list_categories()), set(["app-test1", "app-test2"]))
+        self.assertTrue(pkg_db.in_category("app-test1", "test"))
+        self.assertFalse(pkg_db.in_category("app-test2", "test"))
+        self.assertRaises(InvalidKeyError, pkg_db.in_category, "app-test3", "test")
+        self.assertEqual(set(pkg_db.list_package_names("app-test1")), set(['test', 'test1']))
+        self.assertEqual(set(pkg_db.list_catpkg_names()),set(['app-test1/test', 'app-test1/test1', 'app-test2/test2']))
+        self.assertRaises(InvalidKeyError, pkg_db.list_package_versions, "invalid", "test")
+        self.assertRaises(InvalidKeyError, pkg_db.list_package_versions, "app-test1", "invalid")
+        self.assertEqual(set(pkg_db.list_package_versions("app-test1", "test")), set(['1', '2']))
+        self.assertEqual(set(pkg_db.list_all_packages()), set(packages))
+        self.assertEqual(pkg_db.get_package_description(packages[0]), ebuild_data)
+        self.assertRaises(KeyError, pkg_db.get_package_description, Package("invalid", "invalid", "1"))
+        self.assertEqual(pkg_db.get_max_version("app-test1", "test"), "2")
+        self.assertEqual(pkg_db.get_max_version("app-test1", "test1"), "1")
+        self.assertRaises(InvalidKeyError, pkg_db.get_max_version, "invalid", "invalid")
+        pkg_set = set(packages)
+        for package, data in pkg_db:
+            self.assertTrue(package in pkg_set)
+            self.assertEqual(data, ebuild_data)
+            pkg_set.remove(package)
+        self.assertTrue(not pkg_set)
+
+
+def suite():
+    suite = unittest.TestSuite()
+    suite.addTest(TestDBGenerator('test_functionality'))
+    return suite


             reply	other threads:[~2013-09-18  0:57 UTC|newest]

Thread overview: 20+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-09-18  0:57 Jauhien Piatlicki [this message]
  -- strict thread matches above, loose matches on Subject: below --
2021-05-04 15:50 [gentoo-commits] proj/g-sorcery:master commit in: tests/ Ulrich Müller
2021-05-04 15:50 Ulrich Müller
2021-05-04 15:50 Ulrich Müller
2013-09-18 22:52 Jauhien Piatlicki
2013-09-18 22:52 Jauhien Piatlicki
2013-09-18 22:09 Jauhien Piatlicki
2013-09-18 22:09 Jauhien Piatlicki
2013-09-16 14:33 Jauhien Piatlicki
2013-09-16  0:19 Jauhien Piatlicki
2013-09-15 22:38 Jauhien Piatlicki
2013-09-15 22:38 Jauhien Piatlicki
2013-09-15 22:38 Jauhien Piatlicki
2013-07-17 15:41 Jauhien Piatlicki
2013-07-14 23:39 Jauhien Piatlicki
2013-07-08 23:53 Jauhien Piatlicki
2013-07-02 14:48 Jauhien Piatlicki
2013-07-02 10:21 Jauhien Piatlicki
2013-06-23  0:44 Jauhien Piatlicki
2013-06-23  0:44 Jauhien Piatlicki

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1379465832.b3e47360bd5ccb871e0860c24220259d4fbb3da0.jauhien@gentoo \
    --to=piatlicki@gmail.com \
    --cc=gentoo-commits@lists.gentoo.org \
    --cc=gentoo-dev@lists.gentoo.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox