spec/shared/authenticator.rb in rbnacl-1.1.0 vs spec/shared/authenticator.rb in rbnacl-2.0.0.pre
- old
+ new
@@ -1,69 +1,69 @@
# encoding: binary
shared_examples "authenticator" do
- let (:hex_key) { hex_vector :auth_key }
- let (:key) { test_vector :auth_key }
- let (:message) { test_vector :auth_message }
- let (:tag) { hex2bytes hex_tag }
+ let (:key) { vector :auth_key }
+ let (:message) { vector :auth_message }
context ".new" do
it "accepts a key" do
- expect { described_class.new(key) }.to_not raise_error(ArgumentError)
+ expect { described_class.new(key) }.to_not raise_error(ArgumentError)
end
it "requires a key" do
- expect { described_class.new }.to raise_error(ArgumentError)
+ expect { described_class.new }.to raise_error(ArgumentError)
end
- it "raises on a nil key" do
- expect { described_class.new(nil) }.to raise_error(ArgumentError)
+ it "raises TypeError on a nil key" do
+ expect { described_class.new(nil) }.to raise_error(TypeError)
end
- it "raises on a key which is too long" do
- expect { described_class.new("\0"*33) }.to raise_error(ArgumentError)
+ it "raises ArgumentError on a key which is too long" do
+ expect { described_class.new("\0"*33) }.to raise_error(ArgumentError)
end
- it "raises on a key which is too short" do
- expect { described_class.new("\0"*31) }.to raise_error(ArgumentError)
+ it "raises ArgumentError on a key which is too short" do
+ expect { described_class.new("\0"*31) }.to raise_error(ArgumentError)
end
end
context ".auth" do
it "produces an authenticator" do
described_class.auth(key, message).should eq tag
end
- it "raises on a nil key" do
- expect { described_class.auth(nil, message) }.to raise_error(ArgumentError)
+ it "raises TypeError on a nil key" do
+ expect { described_class.auth(nil, message) }.to raise_error(TypeError)
end
- it "raises on a key which is too long" do
- expect { described_class.auth("\0"*33, message) }.to raise_error(ArgumentError)
+ it "raises ArgumentError on a key which is too long" do
+ expect { described_class.auth("\0"*33, message) }.to raise_error(ArgumentError)
end
end
context ".verify" do
it "verify an authenticator" do
- described_class.verify(key, message, tag).should eq true
+ described_class.verify(key, tag, message).should eq true
end
- it "raises on a nil key" do
- expect { described_class.verify(nil, message, tag) }.to raise_error(ArgumentError)
+ it "raises TypeError on a nil key" do
+ expect { described_class.verify(nil, tag, message) }.to raise_error(TypeError)
end
- it "raises on a key which is too long" do
- expect { described_class.verify("\0"*33, message, tag) }.to raise_error(ArgumentError)
+ it "raises ArgumentError on a key which is too long" do
+ expect { described_class.verify("\0"*33, tag, message) }.to raise_error(ArgumentError)
end
it "fails to validate an invalid authenticator" do
- described_class.verify(key, message+"\0", tag ).should be false
+ described_class.verify(key, tag, message+"\0").should be false
end
+
it "fails to validate a short authenticator" do
- described_class.verify(key, message, tag[0,tag.bytesize - 2]).should be false
+ described_class.verify(key, tag[0,tag.bytesize - 2], message).should be false
end
+
it "fails to validate a long authenticator" do
- described_class.verify(key, message, tag+"\0").should be false
+ described_class.verify(key, tag+"\0", message).should be false
end
end
context "Instance methods" do
@@ -71,44 +71,26 @@
context "#auth" do
it "produces an authenticator" do
authenticator.auth(message).should eq tag
end
-
- it "produces a hex encoded authenticator" do
- authenticator.auth(message, :hex).should eq hex_tag
- end
end
context "#verify" do
- context "raw bytes" do
- it "verifies an authenticator" do
- authenticator.verify(message, tag).should be true
- end
- it "fails to validate an invalid authenticator" do
- authenticator.verify(tag, message+"\0").should be false
- end
- it "fails to validate a short authenticator" do
- authenticator.verify(tag[0,tag.bytesize - 2], message).should be false
- end
- it "fails to validate a long authenticator" do
- authenticator.verify(tag+"\0", message).should be false
- end
+ it "verifies an authenticator" do
+ authenticator.verify(tag, message).should be true
end
- context "hex" do
- it "verifies an hexencoded authenticator" do
- authenticator.verify(message, hex_tag, :hex).should be true
- end
- it "fails to validate an invalid authenticator" do
- authenticator.verify(message+"\0", hex_tag , :hex).should be false
- end
- it "fails to validate a short authenticator" do
- authenticator.verify( message, hex_tag[0,hex_tag.bytesize - 2], :hex).should be false
- end
- it "fails to validate a long authenticator" do
- authenticator.verify(message, hex_tag+"00", :hex).should be false
- end
+ it "fails to validate an invalid authenticator" do
+ authenticator.verify(tag, message+"\0").should be false
+ end
+
+ it "fails to validate a short authenticator" do
+ authenticator.verify(tag[0,tag.bytesize - 2], message).should be false
+ end
+
+ it "fails to validate a long authenticator" do
+ authenticator.verify(tag+"\0", message).should be false
end
end
end
end