76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
|
# File 'ext/xmlsig/t/tc_interface.rb', line 76
def test_interface
signer = Xmlsig::Signer.new(xmlDoc, privateKey)
verifier = Xmlsig::Verifier.new(signer.sign())
assert_equal(1, verifier.verify(pubKey), "verify with public key")
begin
result = verifier.verify()
rescue RuntimeError
result = 1
ensure
assert_equal(1, result, "verify without key")
end
signer = Xmlsig::Signer.new(xmlDoc, privateKey)
x = signer.sign(Xmlsig::XPath.new('//greeting'))
xml = Xmlsig::XmlDoc.new()
assert_equal(0, xml.loadFromFile('t/res/sign_enveloped.xml'), "loadFromFile on XmlDoc")
assert_equal(x.toString(), xml.toString(), "compare signed with desired result")
verifier = Xmlsig::Verifier.new(x)
assert_equal(1, verifier.verify(pubKey), "verify with public key")
signer = Xmlsig::Signer.new(xmlDoc, privateKey)
signer.addReference(Xmlsig::XPath.new('//hello'))
x = signer.sign(Xmlsig::XPath.new('//greeting'))
xml = Xmlsig::XmlDoc.new()
assert_equal(0, xml.loadFromFile('t/res/sign_detached.xml'), "loadFromFile on XmlDoc")
assert_equal(x.toString(), xml.toString(), "compare signed with desired result")
verifier = Xmlsig::Verifier.new(x)
assert_equal(1, verifier.verify(pubKey), "verify with public key")
assert_equal(1, verifier.isReferenced(Xmlsig::XPath.new('//hello[1]')), "isReferenced on verify")
xml = xmlDoc
signer = Xmlsig::Signer.new(xml, privateKey)
signer.addReference(Xmlsig::XPath.new('//hello'))
assert_equal(0, signer.signInPlace(Xmlsig::XPath.new('//greeting')), "signInPlace on signer")
x = Xmlsig::XmlDoc.new()
assert_equal(0, x.loadFromFile('t/res/sign_detached.xml'), "loadFromFile on XmlDoc")
assert_equal(x.toString(), xml.toString(), "compare signed with desired result")
xml = xmlDoc
signer = Xmlsig::Signer.new(xml, privateKey)
assert_equal(0, signer.signInPlace(), "signInPlace on signer")
verifier = Xmlsig::Verifier.new(xml)
assert_equal(1, verifier.verify(pubKey), "verify with public key")
xml = xmlDoc
signer = Xmlsig::Signer.new(xml, privateKey, pubKey)
assert_equal(0, signer.signInPlace(Xmlsig::XPath.new('//greeting')), "signInPlace on signer")
x = Xmlsig::XmlDoc.new()
assert_equal(0, x.loadFromFile('t/res/sign_enveloped_withkey.xml'), "loadFromFile on XmlDoc")
assert_equal(x.toString(), xml.toString(), "compare signed with desired result")
xml = xmlDoc
signer = Xmlsig::Signer.new(xml, privateKey)
signer.useExclusiveCanonicalizer('')
assert_equal(0, signer.signInPlace(Xmlsig::XPath.new('//greeting')), "signInPlace on signer")
x = Xmlsig::XmlDoc.new()
assert_equal(0, x.loadFromFile('t/res/sign_enveloped_exc_c14n.xml'), "loadFromFile on XmlDoc")
assert_equal(x.toString(), xml.toString(), "compare signed with desired result")
signer = Xmlsig::Signer.new(xmlDoc, privateKey)
signer.addCertFromFile('t/res/rsacert.pem', 'pem')
signer.attachPublicKey(1)
xml = signer.sign(Xmlsig::XPath.new('//greeting'))
x = Xmlsig::XmlDoc.new()
assert_equal(0, x.loadFromFile('t/res/sign_enveloped_withcert.xml'), "loadFromFile on XmlDoc")
assert_equal(x.toString(), xml.toString(), "compare signed with desired result")
verifier = Xmlsig::Verifier.new(xml)
eCert = verifier.getCertificate()
assert_kind_of(Object, eCert, "getCertificate on verifier")
xml = xmlDoc
signer = Xmlsig::Signer.new(xml, HMACKey())
assert_equal(0, signer.signInPlace(Xmlsig::XPath.new('//greeting')), "signInPlace on signer")
x = Xmlsig::XmlDoc.new()
assert_equal(0, x.loadFromFile('t/res/sign_enveloped_hmac.xml'), "loadFromFile on XmlDoc")
assert_equal(x.toString(), xml.toString(), "compare signed with desired result")
end
|