summaryrefslogtreecommitdiffabout
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--test/Makefile.am5
-rw-r--r--test/html/spaced-link-attrs.html8
-rw-r--r--test/html/spaced-links.html8
-rw-r--r--test/html/unclosed-head.html7
-rw-r--r--test/test.cc7
5 files changed, 32 insertions, 3 deletions
diff --git a/test/Makefile.am b/test/Makefile.am
index 0dbba65..550078a 100644
--- a/test/Makefile.am
+++ b/test/Makefile.am
@@ -1,8 +1,11 @@
1noinst_PROGRAMS = test 1noinst_PROGRAMS = test
2 2
3INCLUDES = -I${top_srcdir}/include/ 3INCLUDES = -I${top_srcdir}/include/
4 4
5test_SOURCES = test.cc 5test_SOURCES = test.cc
6test_LDADD = ${top_builddir}/lib/libopkele.la 6test_LDADD = ${top_builddir}/lib/libopkele.la
7 7
8EXTRA_DIST=$(addsuffix .html,$(addprefix html/, empty head-in-body hkn-delegate hkn-server hkn in-body)) 8EXTRA_DIST=$(addsuffix .html,$(addprefix html/, \
9 empty head-in-body hkn-delegate hkn-server hkn in-body \
10 unclosed-head spaced-links spaced-link-attrs \
11 ))
diff --git a/test/html/spaced-link-attrs.html b/test/html/spaced-link-attrs.html
new file mode 100644
index 0000000..33905c0
--- a/dev/null
+++ b/test/html/spaced-link-attrs.html
@@ -0,0 +1,8 @@
1<html>
2 <head>
3 <link rel=" openid.server " href=" http://www.klever.net/openid.server" />
4 <link rel=" openid.delegate" href="http://hacker.klever.net/ " />
5 </head>
6 <body>
7 </body>
8</html>
diff --git a/test/html/spaced-links.html b/test/html/spaced-links.html
new file mode 100644
index 0000000..a958907
--- a/dev/null
+++ b/test/html/spaced-links.html
@@ -0,0 +1,8 @@
1<html>
2 <head>
3 < link rel = "openid.server" href = "http://www.klever.net/openid.server" />
4 <link rel="openid.delegate" href='http://hacker.klever.net/' />
5 </head>
6 <body>
7 </body>
8</html>
diff --git a/test/html/unclosed-head.html b/test/html/unclosed-head.html
new file mode 100644
index 0000000..9c6f2ea
--- a/dev/null
+++ b/test/html/unclosed-head.html
@@ -0,0 +1,7 @@
1<html>
2 <head>
3 <link rel="openid.server" href="http://www.klever.net/openid.server" />
4 <link rel="openid.delegate" href="http://hacker.klever.net/" />
5 <body>
6 </body>
7</html>
diff --git a/test/test.cc b/test/test.cc
index f0526c6..10283e6 100644
--- a/test/test.cc
+++ b/test/test.cc
@@ -1,68 +1,71 @@
1#include <iostream> 1#include <iostream>
2#include <stdexcept> 2#include <stdexcept>
3using namespace std; 3using namespace std;
4#include <opkele/exception.h> 4#include <opkele/exception.h>
5#include <opkele/consumer.h> 5#include <opkele/consumer.h>
6 6
7#include "config.h" 7#include "config.h"
8 8
9class failed_test : public opkele::exception { 9class failed_test : public opkele::exception {
10 public: 10 public:
11 failed_test(OPKELE_E_PARS) 11 failed_test(OPKELE_E_PARS)
12 : exception(OPKELE_E_CONS) { } 12 : exception(OPKELE_E_CONS) { }
13}; 13};
14 14
15class dummy_consumer_t : public opkele::consumer_t { 15class dummy_consumer_t : public opkele::consumer_t {
16 public: 16 public:
17 virtual opkele::assoc_t store_assoc(const string& server,const string& handle,const opkele::secret_t& secret,int expires_in) { 17 virtual opkele::assoc_t store_assoc(const string& server,const string& handle,const opkele::secret_t& secret,int expires_in) {
18 throw opkele::not_implemented(OPKELE_CP_ "Not implemented"); 18 throw opkele::not_implemented(OPKELE_CP_ "Not implemented");
19 } 19 }
20 virtual opkele::assoc_t retrieve_assoc(const string& server,const string& handle) { 20 virtual opkele::assoc_t retrieve_assoc(const string& server,const string& handle) {
21 throw opkele::not_implemented(OPKELE_CP_ "Not implemented"); 21 throw opkele::not_implemented(OPKELE_CP_ "Not implemented");
22 } 22 }
23 virtual void invalidate_assoc(const string& server,const string& handle) { 23 virtual void invalidate_assoc(const string& server,const string& handle) {
24 throw opkele::not_implemented(OPKELE_CP_ "Not implemented"); 24 throw opkele::not_implemented(OPKELE_CP_ "Not implemented");
25 } 25 }
26}; 26};
27 27
28 28
29void test_retrieve_links(const string& f,bool success,const string& s="",const string& d="") { 29void test_retrieve_links(const string& f,bool success,const string& s="",const string& d="") {
30 dummy_consumer_t dc; 30 dummy_consumer_t dc;
31 string server, delegate; 31 string server, delegate;
32 try { 32 try {
33 dc.retrieve_links("file://" OPKELE_SRC_DIR "/test/html/"+f,server,delegate); 33 dc.retrieve_links("file://" OPKELE_SRC_DIR "/test/html/"+f,server,delegate);
34 if(!success) 34 if(!success)
35 throw failed_test(OPKELE_CP_ "Retrieved links when it shouldn't"); 35 throw failed_test(OPKELE_CP_ "Retrieved links when it shouldn't");
36 if(server!=s) 36 if(server!=s)
37 throw failed_test(OPKELE_CP_ "retrieve_links test failed, expected server '"+s+"', got '"+server+"'"); 37 throw failed_test(OPKELE_CP_ "retrieve_links test failed, expected server '"+s+"', got '"+server+"'");
38 if(delegate!=d) 38 if(delegate!=d)
39 throw failed_test(OPKELE_CP_ "retrieve_links test failed, expected delegate '"+d+"', got '"+delegate+"'"); 39 throw failed_test(OPKELE_CP_ "retrieve_links test failed, expected delegate '"+d+"', got '"+delegate+"'");
40 }catch(opkele::bad_input& obi) { 40 }catch(opkele::bad_input& obi) {
41 if(success) 41 if(success)
42 throw failed_test(OPKELE_CP_ "Test failed"); 42 throw failed_test(OPKELE_CP_ "Test '"+f+"' failed due to 'bad_input'["+obi.what()+"]");
43 }catch(opkele::failed_assertion& ofa) { 43 }catch(opkele::failed_assertion& ofa) {
44 if(success) 44 if(success)
45 throw failed_test(OPKELE_CP_ "Test failed"); 45 throw failed_test(OPKELE_CP_ "Test '"+f+"' failed due to 'failed_assertion'["+ofa.what()+"]");
46 } 46 }
47} 47}
48 48
49void test_retrieve_links() { 49void test_retrieve_links() {
50 test_retrieve_links("empty.html",false); 50 test_retrieve_links("empty.html",false);
51 test_retrieve_links("in-body.html",false); 51 test_retrieve_links("in-body.html",false);
52 test_retrieve_links("head-in-body.html",false); 52 test_retrieve_links("head-in-body.html",false);
53 test_retrieve_links("hkn.html",true,"http://www.klever.net/openid.server","http://hacker.klever.net/"); 53 test_retrieve_links("hkn.html",true,"http://www.klever.net/openid.server","http://hacker.klever.net/");
54 test_retrieve_links("hkn-server.html",true,"http://www.klever.net/openid.server"); 54 test_retrieve_links("hkn-server.html",true,"http://www.klever.net/openid.server");
55 test_retrieve_links("hkn-delegate.html",false); 55 test_retrieve_links("hkn-delegate.html",false);
56 test_retrieve_links("unclosed-head.html",true,"http://www.klever.net/openid.server","http://hacker.klever.net/");
57 test_retrieve_links("spaced-links.html",true,"http://www.klever.net/openid.server","http://hacker.klever.net/");
58 test_retrieve_links("spaced-link-attrs.html",true,"http://www.klever.net/openid.server","http://hacker.klever.net/");
56} 59}
57 60
58main() { 61main() {
59 try { 62 try {
60 test_retrieve_links(); 63 test_retrieve_links();
61 }catch(failed_test& ft) { 64 }catch(failed_test& ft) {
62 cerr << "Test failed: " << ft.what() << endl; 65 cerr << "Test failed: " << ft.what() << endl;
63 }catch(exception& e) { 66 }catch(exception& e) {
64 cerr << "oops: " << e.what() << endl; 67 cerr << "oops: " << e.what() << endl;
65 _exit(1); 68 _exit(1);
66 } 69 }
67 _exit(0); 70 _exit(0);
68} 71}