summaryrefslogtreecommitdiffstats
path: root/test/path_test.cpp
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2012-08-14 04:22:07 +0000
committerDavid Robillard <d@drobilla.net>2012-08-14 04:22:07 +0000
commit2a429ca76b97cca197f105b665271360b74f6917 (patch)
treed25d206910bd4a84050918693816240c26d7d0ae /test/path_test.cpp
parent8bf87dc2367caf9d82dbda0382363cda400971dc (diff)
downloadraul-2a429ca76b97cca197f105b665271360b74f6917.tar.gz
raul-2a429ca76b97cca197f105b665271360b74f6917.tar.bz2
raul-2a429ca76b97cca197f105b665271360b74f6917.zip
Remove glib dependency.
Make Symbol, URI, and Path simpler derivatives of std::string. 100% test coverage by line for Symbol, URI, Path, AtomicInt, and AtomicPtr. Add Raul::Exception. git-svn-id: http://svn.drobilla.net/lad/trunk/raul@4686 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'test/path_test.cpp')
-rw-r--r--test/path_test.cpp64
1 files changed, 39 insertions, 25 deletions
diff --git a/test/path_test.cpp b/test/path_test.cpp
index f267595..1bdd99e 100644
--- a/test/path_test.cpp
+++ b/test/path_test.cpp
@@ -14,8 +14,9 @@
along with Raul. If not, see <http://www.gnu.org/licenses/>.
*/
+#include <cstring>
#include <iostream>
-#include <list>
+
#include "raul/log.hpp"
#include "raul/Path.hpp"
@@ -31,23 +32,6 @@ main()
return 1; \
} } while (0)
- list<string> names;
- names.push_back("Dry/Wet Balance");
- names.push_back("foo+1bar(baz)");
- names.push_back("ThisCRAR");
- names.push_back("NAME");
- names.push_back("thing with a bunch of spaces");
- names.push_back("thing-with-a-bunch-of-dashes");
- names.push_back("CamelCaseABC");
- names.push_back("Signal Level [dB]");
- names.push_back("Gain dB");
- names.push_back("Dry/Wet Balance");
- names.push_back("Phaser1 - Similar to CSound's phaser1 by Sean Costello");
-
- for (list<string>::iterator i = names.begin(); i != names.end(); ++i) {
- CHECK(strcmp(Symbol::symbolify(*i).c_str(), ""));
- }
-
CHECK(Path("/foo/bar").parent() == Path("/foo"));
CHECK(Path("/foo").parent() == Path("/"));
CHECK(Path("/").parent() == Path("/"));
@@ -68,13 +52,13 @@ main()
CHECK(Path::is_valid("/"));
CHECK(!Path::is_valid("/foo/3foo/bar"));
- CHECK(Path::descendant_comparator("/", "/foo"));
- CHECK(Path::descendant_comparator("/foo", "/foo/bar"));
- CHECK(Path::descendant_comparator("/foo", "/foo"));
- CHECK(Path::descendant_comparator("/", "/"));
- CHECK(!Path::descendant_comparator("/baz", "/"));
- CHECK(!Path::descendant_comparator("/foo", "/bar"));
- CHECK(!Path::descendant_comparator("/foo/bar", "/foo"));
+ CHECK(Path::descendant_comparator(Path("/"), Path("/foo")));
+ CHECK(Path::descendant_comparator(Path("/foo"), Path("/foo/bar")));
+ CHECK(Path::descendant_comparator(Path("/foo"), Path("/foo")));
+ CHECK(Path::descendant_comparator(Path("/"), Path("/")));
+ CHECK(!Path::descendant_comparator(Path("/baz"), Path("/")));
+ CHECK(!Path::descendant_comparator(Path("/foo"), Path("/bar")));
+ CHECK(!Path::descendant_comparator(Path("/foo/bar"), Path("/foo")));
CHECK(!Symbol::is_valid(""));
CHECK(!Symbol::is_valid("/I/have/slashes"));
@@ -82,5 +66,35 @@ main()
CHECK(!Symbol::is_valid("0illegalleadingdigit"));
CHECK(strcmp(Symbol::symbolify("").c_str(), ""));
+ CHECK(Path("/foo").child(Symbol("bar")) == "/foo/bar");
+ CHECK(Path("/foo").child(Path("/bar/baz")) == "/foo/bar/baz");
+ CHECK(Path("/foo").child(Path("/")) == "/foo");
+
+ CHECK(!strcmp(Path("/foo").symbol(), "foo"));
+ CHECK(!strcmp(Path("/foo/bar").symbol(), "bar"));
+ CHECK(!strcmp(Path("/").symbol(), ""));
+
+ Path original(std::string("/foo/bar"));
+ Path copy(original);
+ CHECK(original == copy);
+
+ bool valid = true;
+ try {
+ Path path("/ends/in/slash/");
+ } catch (const Path::BadPath& e) {
+ std::cerr << "Caught exception: " << e.what() << std::endl;
+ valid = false;
+ }
+ CHECK(!valid);
+
+ valid = true;
+ try {
+ Path path(std::string("/has//double/slash"));
+ } catch (const Path::BadPath& e) {
+ std::cerr << "Caught exception: " << e.what() << std::endl;
+ valid = false;
+ }
+ CHECK(!valid);
+
return 0;
}