]> git.tdb.fi Git - libs/datafile.git/blobdiff - tests/collection.cpp
Cosmetic changes
[libs/datafile.git] / tests / collection.cpp
index 41dc7e482543ccaa31bc3e9346addab68ddcec34..6c9ef195bc2a0ea3166fc5ba07bb2c971425f97b 100644 (file)
@@ -23,13 +23,16 @@ public:
 private:
        void load();
        void contains();
-       void contains_future();
+       void contains_base();
+       void contains_loadable();
        void names();
-       void names_future();
+       void names_base();
+       void names_loadable();
        void fetch();
        void nonexistent();
        void type_mismatch();
        void create();
+       void list_loadable();
        void name_collision();
 };
 
@@ -69,6 +72,9 @@ class Bar: public Base
 class Sub: public Bar
 { };
 
+class Bus: public Bar
+{ };
+
 
 class TestSource: public DataFile::CollectionSource
 {
@@ -76,6 +82,7 @@ public:
        virtual bool is_loadable(const DataFile::CollectionItemTypeBase &, const std::string &) const;
        virtual NameList get_names(const DataFile::CollectionItemTypeBase &) const;
        virtual void load(DataFile::Collection &, const DataFile::CollectionItemTypeBase &, const std::string &) const;
+       virtual IO::Seekable *open(const string &) const { return 0; }
 };
 
 
@@ -96,13 +103,16 @@ CollectionTests::CollectionTests()
 {
        add(&CollectionTests::load, "Load objects");
        add(&CollectionTests::contains, "Containment test");
-       add(&CollectionTests::contains_future, "Future containment test");
+       add(&CollectionTests::contains_base, "Base class containment test");
+       add(&CollectionTests::contains_loadable, "Loadable containment test");
        add(&CollectionTests::names, "List object names");
-       add(&CollectionTests::names_future, "List future object names");
+       add(&CollectionTests::names_base, "List base class object names");
+       add(&CollectionTests::names_loadable, "List loadable object names");
        add(&CollectionTests::fetch, "Fetch objects");
        add(&CollectionTests::nonexistent, "Nonexistent object").expect_throw<key_error>();
        add(&CollectionTests::type_mismatch, "Type mismatch").expect_throw<Msp::type_mismatch>();
        add(&CollectionTests::create, "Create object");
+       add(&CollectionTests::list_loadable, "List loadable objects");
        add(&CollectionTests::name_collision, "Name collision").expect_throw<Msp::key_error>();
 
        collection = new TestCollection;
@@ -119,7 +129,8 @@ void CollectionTests::load()
                "foo \"a\" { tag 1; };\n"
                "foo \"b\" { tag 2; };\n"
                "bar \"c\" { tag 3; };\n"
-               "sub \"d\" { tag 4; };\n";
+               "sub \"d\" { tag 4; };\n"
+               "bus \"e\" { tag 5; };\n";
 
        IO::Memory mem(input, sizeof(input)-1);
        DataFile::Parser parser(mem, "-");
@@ -135,7 +146,14 @@ void CollectionTests::contains()
        EXPECT(!ccoll->contains<Foo>("c"));
 }
 
-void CollectionTests::contains_future()
+void CollectionTests::contains_base()
+{
+       const TestCollection *ccoll = collection;
+       EXPECT(ccoll->contains<Bar>("d"));
+       EXPECT(ccoll->contains<Sub>("d"));
+}
+
+void CollectionTests::contains_loadable()
 {
        const TestCollection *ccoll = collection;
        EXPECT(!ccoll->contains<Foo>("f"));
@@ -152,7 +170,18 @@ void CollectionTests::names()
        EXPECT_EQUAL(nm_set.count("b"), 1);
 }
 
-void CollectionTests::names_future()
+void CollectionTests::names_base()
+{
+       const TestCollection *ccoll = collection;
+       list<string> nm = ccoll->get_names<Bar>();
+       EXPECT_EQUAL(nm.size(), 3);
+       set<string> nm_set(nm.begin(), nm.end());
+       EXPECT_EQUAL(nm_set.count("c"), 1);
+       EXPECT_EQUAL(nm_set.count("d"), 1);
+       EXPECT_EQUAL(nm_set.count("e"), 1);
+}
+
+void CollectionTests::names_loadable()
 {
        list<string> nm = collection->get_names<Foo>();
        EXPECT_EQUAL(nm.size(), 3);
@@ -189,6 +218,14 @@ void CollectionTests::create()
        EXPECT(Foo::get_create_count()>foo_count);
 }
 
+void CollectionTests::list_loadable()
+{
+       list<Foo *> nm = collection->get_list<Foo>();
+       EXPECT_EQUAL(nm.size(), 3);
+       set<Foo *> nm_set(nm.begin(), nm.end());
+       EXPECT_EQUAL(nm_set.size(), nm.size());
+}
+
 void CollectionTests::name_collision()
 {
        RefPtr<Foo> a = new Foo;
@@ -241,6 +278,7 @@ TestCollection::TestCollection()
        add_type<Foo>().keyword("foo").creator(&TestCollection::create_foo);
        add_type<Bar>().keyword("bar");
        add_type<Sub>().keyword("sub").base<Bar>();
+       add_type<Bus>().keyword("bus").base<Bar>();
        add_source(source);
 }