aboutsummaryrefslogtreecommitdiff
path: root/0.8.0/paludis/qa/package_name_check_TEST.cc
diff options
context:
space:
mode:
Diffstat (limited to '0.8.0/paludis/qa/package_name_check_TEST.cc')
-rw-r--r--0.8.0/paludis/qa/package_name_check_TEST.cc104
1 files changed, 104 insertions, 0 deletions
diff --git a/0.8.0/paludis/qa/package_name_check_TEST.cc b/0.8.0/paludis/qa/package_name_check_TEST.cc
new file mode 100644
index 0000000..f304126
--- /dev/null
+++ b/0.8.0/paludis/qa/package_name_check_TEST.cc
@@ -0,0 +1,104 @@
+/* vim: set sw=4 sts=4 et foldmethod=syntax : */
+
+/*
+ * Copyright (c) 2006 Ciaran McCreesh <ciaranm@ciaranm.org>
+ *
+ * This file is part of the Paludis package manager. Paludis is free software;
+ * you can redistribute it and/or modify it under the terms of the GNU General
+ * Public License version 2, as published by the Free Software Foundation.
+ *
+ * Paludis is distributed in the hope that it will be useful, but WITHOUT ANY
+ * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
+ * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
+ * details.
+ *
+ * You should have received a copy of the GNU General Public License along with
+ * this program; if not, write to the Free Software Foundation, Inc., 59 Temple
+ * Place, Suite 330, Boston, MA 02111-1307 USA
+ */
+
+#include <paludis/qa/package_name_check.hh>
+#include <test/test_framework.hh>
+#include <test/test_runner.hh>
+
+using namespace paludis;
+using namespace paludis::qa;
+using namespace test;
+
+namespace test_cases
+{
+ struct PackageNameCheckBothValidTest : TestCase
+ {
+ PackageNameCheckBothValidTest() : TestCase("package name both valid") { }
+
+ void run()
+ {
+ FSEntry e("package_name_check_TEST_dir");
+ TEST_CHECK(e.exists());
+ TEST_CHECK(e.is_directory());
+
+ FSEntry f1(e / "valid-cat" / "valid-pkg");
+ TEST_CHECK(f1.exists());
+ CheckResult r1((*(*PackageDirCheckMaker::get_instance()->find_maker(
+ PackageNameCheck::identifier()))())(f1));
+ TEST_CHECK(r1.empty());
+ }
+ } test_package_name_check_both_valid;
+
+ struct PackageNameCheckCatInvalidTest : TestCase
+ {
+ PackageNameCheckCatInvalidTest() : TestCase("package name cat invalid") { }
+
+ void run()
+ {
+ FSEntry e("package_name_check_TEST_dir");
+ TEST_CHECK(e.exists());
+ TEST_CHECK(e.is_directory());
+
+ FSEntry f1(e / "invalid-cat!" / "valid-pkg");
+ TEST_CHECK(f1.exists());
+ CheckResult r1((*(*PackageDirCheckMaker::get_instance()->find_maker(
+ PackageNameCheck::identifier()))())(f1));
+ TEST_CHECK(! r1.empty());
+ TEST_CHECK_EQUAL(std::distance(r1.begin(), r1.end()), 1);
+ }
+ } test_package_name_check_cat_invalid;
+
+ struct PackageNameCheckPkgInvalidTest : TestCase
+ {
+ PackageNameCheckPkgInvalidTest() : TestCase("package name pkg invalid") { }
+
+ void run()
+ {
+ FSEntry e("package_name_check_TEST_dir");
+ TEST_CHECK(e.exists());
+ TEST_CHECK(e.is_directory());
+
+ FSEntry f1(e / "valid-cat" / "invalid-pkg...");
+ TEST_CHECK(f1.exists());
+ CheckResult r1((*(*PackageDirCheckMaker::get_instance()->find_maker(
+ PackageNameCheck::identifier()))())(f1));
+ TEST_CHECK(! r1.empty());
+ TEST_CHECK_EQUAL(std::distance(r1.begin(), r1.end()), 1);
+ }
+ } test_package_name_check_pkg_invalid;
+
+ struct PackageNameCheckBothInvalidTest : TestCase
+ {
+ PackageNameCheckBothInvalidTest() : TestCase("package name both invalid") { }
+
+ void run()
+ {
+ FSEntry e("package_name_check_TEST_dir");
+ TEST_CHECK(e.exists());
+ TEST_CHECK(e.is_directory());
+
+ FSEntry f1(e / "invalid-cat!" / "invalid-pkg...");
+ TEST_CHECK(f1.exists());
+ CheckResult r1((*(*PackageDirCheckMaker::get_instance()->find_maker(
+ PackageNameCheck::identifier()))())(f1));
+ TEST_CHECK(! r1.empty());
+ TEST_CHECK_EQUAL(std::distance(r1.begin(), r1.end()), 2);
+ }
+ } test_package_name_check_both_invalid;
+}