summaryrefslogtreecommitdiffabout
Side-by-side diff
Diffstat (more/less context) (show whitespace changes)
-rw-r--r--test/html/2rels.html7
-rw-r--r--test/test.cc1
2 files changed, 8 insertions, 0 deletions
diff --git a/test/html/2rels.html b/test/html/2rels.html
new file mode 100644
index 0000000..8773c55
--- a/dev/null
+++ b/test/html/2rels.html
@@ -0,0 +1,7 @@
+<html>
+ <head>
+ <link rel="openid.server openid.delegate" href="http://www.klever.net/openid.server" />
+ </head>
+ <body>
+ </body>
+</html>
diff --git a/test/test.cc b/test/test.cc
index 10283e6..7def12f 100644
--- a/test/test.cc
+++ b/test/test.cc
@@ -27,45 +27,46 @@ class dummy_consumer_t : public opkele::consumer_t {
void test_retrieve_links(const string& f,bool success,const string& s="",const string& d="") {
dummy_consumer_t dc;
string server, delegate;
try {
dc.retrieve_links("file://" OPKELE_SRC_DIR "/test/html/"+f,server,delegate);
if(!success)
throw failed_test(OPKELE_CP_ "Retrieved links when it shouldn't");
if(server!=s)
throw failed_test(OPKELE_CP_ "retrieve_links test failed, expected server '"+s+"', got '"+server+"'");
if(delegate!=d)
throw failed_test(OPKELE_CP_ "retrieve_links test failed, expected delegate '"+d+"', got '"+delegate+"'");
}catch(opkele::bad_input& obi) {
if(success)
throw failed_test(OPKELE_CP_ "Test '"+f+"' failed due to 'bad_input'["+obi.what()+"]");
}catch(opkele::failed_assertion& ofa) {
if(success)
throw failed_test(OPKELE_CP_ "Test '"+f+"' failed due to 'failed_assertion'["+ofa.what()+"]");
}
}
void test_retrieve_links() {
test_retrieve_links("empty.html",false);
test_retrieve_links("in-body.html",false);
test_retrieve_links("head-in-body.html",false);
test_retrieve_links("hkn.html",true,"http://www.klever.net/openid.server","http://hacker.klever.net/");
test_retrieve_links("hkn-server.html",true,"http://www.klever.net/openid.server");
test_retrieve_links("hkn-delegate.html",false);
test_retrieve_links("unclosed-head.html",true,"http://www.klever.net/openid.server","http://hacker.klever.net/");
test_retrieve_links("spaced-links.html",true,"http://www.klever.net/openid.server","http://hacker.klever.net/");
test_retrieve_links("spaced-link-attrs.html",true,"http://www.klever.net/openid.server","http://hacker.klever.net/");
+ test_retrieve_links("2rels.html",true,"http://www.klever.net/openid.server","http://www.klever.net/openid.server");
}
main() {
try {
test_retrieve_links();
}catch(failed_test& ft) {
cerr << "Test failed: " << ft.what() << endl;
}catch(exception& e) {
cerr << "oops: " << e.what() << endl;
_exit(1);
}
_exit(0);
}