summaryrefslogtreecommitdiffstats
path: root/test
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
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')
-rw-r--r--test/path_test.cpp64
-rw-r--r--test/symbol_test.cpp77
-rw-r--r--test/table_test.cpp5
-rw-r--r--test/uri_test.cpp61
4 files changed, 180 insertions, 27 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;
}
diff --git a/test/symbol_test.cpp b/test/symbol_test.cpp
new file mode 100644
index 0000000..9726001
--- /dev/null
+++ b/test/symbol_test.cpp
@@ -0,0 +1,77 @@
+/*
+ This file is part of Raul.
+ Copyright 2007-2012 David Robillard <http://drobilla.net>
+
+ Raul is free software: you can redistribute it and/or modify it under the
+ terms of the GNU General Public License as published by the Free Software
+ Foundation, either version 3 of the License, or any later version.
+
+ Raul 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 Raul. If not, see <http://www.gnu.org/licenses/>.
+*/
+
+#include <cstring>
+#include <iostream>
+#include <list>
+
+#include "raul/log.hpp"
+#include "raul/Path.hpp"
+
+using namespace std;
+using namespace Raul;
+
+int
+main()
+{
+#define CHECK(cond) \
+ do { if (!(cond)) { \
+ error << "Test failed: " << (cond) << endl; \
+ 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");
+ names.push_back("");
+
+ for (list<string>::iterator i = names.begin(); i != names.end(); ++i) {
+ CHECK(!Symbol::symbolify(*i).empty());
+ }
+
+ Symbol original("sym");
+ Symbol copy(original);
+ CHECK(original == copy);
+
+ bool valid = true;
+ try {
+ Symbol symbol("0startswithdigit");
+ } catch (const Symbol::BadSymbol& e) {
+ std::cerr << "Caught exception: " << e.what() << std::endl;
+ valid = false;
+ }
+ CHECK(!valid);
+
+ valid = true;
+ try {
+ Symbol symbol(std::string("invalid/symbol"));
+ } catch (const Symbol::BadSymbol& e) {
+ std::cerr << "Caught exception: " << e.what() << std::endl;
+ valid = false;
+ }
+ CHECK(!valid);
+
+ return 0;
+}
diff --git a/test/table_test.cpp b/test/table_test.cpp
index 70ab5b1..f372d7c 100644
--- a/test/table_test.cpp
+++ b/test/table_test.cpp
@@ -14,12 +14,13 @@
along with Raul. If not, see <http://www.gnu.org/licenses/>.
*/
-#include <string>
+#include <cstring>
#include <iostream>
-#include <utility>
#include <map>
#include <set>
+#include <string>
#include <sys/time.h>
+#include <utility>
#include "raul/log.hpp"
#include "raul/PathTable.hpp"
diff --git a/test/uri_test.cpp b/test/uri_test.cpp
new file mode 100644
index 0000000..d3b9a99
--- /dev/null
+++ b/test/uri_test.cpp
@@ -0,0 +1,61 @@
+/*
+ This file is part of Raul.
+ Copyright 2007-2012 David Robillard <http://drobilla.net>
+
+ Raul is free software: you can redistribute it and/or modify it under the
+ terms of the GNU General Public License as published by the Free Software
+ Foundation, either version 3 of the License, or any later version.
+
+ Raul 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 Raul. If not, see <http://www.gnu.org/licenses/>.
+*/
+
+#include <iostream>
+
+#include "raul/log.hpp"
+#include "raul/URI.hpp"
+
+using namespace std;
+using namespace Raul;
+
+int
+main()
+{
+#define CHECK(cond) \
+ do { if (!(cond)) { \
+ error << "Test failed: " << (cond) << endl; \
+ assert(0); \
+ return 1; \
+ } } while (0)
+
+ CHECK(URI("http://example.org").scheme() == "http");
+ CHECK(URI("svn+ssh://example.org/").scheme() == "svn+ssh");
+ CHECK(URI("osc.udp://example.org/").scheme() == "osc.udp");
+ CHECK(URI("weird-scheme://example.org/").scheme() == "weird-scheme");
+
+ URI original(std::string("http://example.org"));
+ URI copy(original);
+ CHECK(original == copy);
+
+ bool valid = true;
+ try {
+ URI uri("not/a/uri");
+ } catch (const URI::BadURI& e) {
+ valid = false;
+ }
+ CHECK(!valid);
+
+ valid = true;
+ try {
+ URI uri(std::string("/this/is/a/path"));
+ } catch (const URI::BadURI& e) {
+ valid = false;
+ }
+ CHECK(!valid);
+
+ return 0;
+}