From 05e4c8dc51cd25efc272d8eed086da7e141105d5 Mon Sep 17 00:00:00 2001 From: Benjamin Neff Date: Sun, 20 Dec 2015 21:41:39 +0100 Subject: [PATCH] improve key specs in federation_callbacks_spec.rb --- spec/federation_callbacks_spec.rb | 90 +++++++++++++++---------------- 1 file changed, 42 insertions(+), 48 deletions(-) diff --git a/spec/federation_callbacks_spec.rb b/spec/federation_callbacks_spec.rb index dc763b05c0b..80d2ba6deb8 100644 --- a/spec/federation_callbacks_spec.rb +++ b/spec/federation_callbacks_spec.rb @@ -149,120 +149,114 @@ end end - def create_a_local_person - FactoryGirl.create(:user).person - end - - def create_a_remote_person - FactoryGirl.create(:person) - end + let(:local_person) { FactoryGirl.create(:user).person } + let(:remote_person) { FactoryGirl.create(:person) } + let(:post_by_a_local_person) { FactoryGirl.create(:status_message, author: local_person) } + let(:post_by_a_remote_person) { FactoryGirl.create(:status_message, author: remote_person) } - def create_post_by_a_local_person - FactoryGirl.create(:status_message, author: create_a_local_person).guid - end - - def create_post_by_a_remote_person - FactoryGirl.create(:status_message, author: create_a_remote_person).guid - end - - describe :fetch_private_key_by_diaspora_id do + describe ":fetch_private_key_by_diaspora_id" do it "returns a private key for a local user" do - expect( - DiasporaFederation.callbacks.trigger(described_class, create_a_local_person.diaspora_handle) - ).not_to be_nil + key = DiasporaFederation.callbacks.trigger(:fetch_private_key_by_diaspora_id, local_person.diaspora_handle) + expect(key).to be_a(OpenSSL::PKey::RSA) + expect(key.to_s).to eq(local_person.owner.serialized_private_key) end it "returns nil for a remote user" do expect( - DiasporaFederation.callbacks.trigger(described_class, create_a_remote_person.diaspora_handle) + DiasporaFederation.callbacks.trigger(:fetch_private_key_by_diaspora_id, remote_person.diaspora_handle) ).to be_nil end it "returns nil for an unknown id" do expect( - DiasporaFederation.callbacks.trigger(described_class, FactoryGirl.generate(:diaspora_id)) + DiasporaFederation.callbacks.trigger(:fetch_private_key_by_diaspora_id, FactoryGirl.generate(:diaspora_id)) ).to be_nil end end - describe :fetch_author_private_key_by_entity_guid do + describe ":fetch_author_private_key_by_entity_guid" do it "returns a private key for a post by a local user" do - expect( - DiasporaFederation.callbacks.trigger(described_class, "Post", create_post_by_a_local_person) - ).not_to be_nil + key = DiasporaFederation.callbacks.trigger(:fetch_author_private_key_by_entity_guid, + "Post", post_by_a_local_person.guid) + expect(key).to be_a(OpenSSL::PKey::RSA) + expect(key.to_s).to eq(post_by_a_local_person.author.owner.serialized_private_key) end it "returns nil for a post by a remote user" do expect( - DiasporaFederation.callbacks.trigger(described_class, "Post", create_post_by_a_remote_person) + DiasporaFederation.callbacks.trigger(:fetch_author_private_key_by_entity_guid, + "Post", post_by_a_remote_person.guid) ).to be_nil end it "returns nil for an unknown post" do expect( - DiasporaFederation.callbacks.trigger(described_class, "Post", FactoryGirl.generate(:guid)) + DiasporaFederation.callbacks.trigger(:fetch_author_private_key_by_entity_guid, + "Post", FactoryGirl.generate(:guid)) ).to be_nil end end - describe :fetch_public_key_by_diaspora_id do + describe ":fetch_public_key_by_diaspora_id" do it "returns a public key for a person" do - expect( - DiasporaFederation.callbacks.trigger(described_class, create_a_remote_person.diaspora_handle) - ).not_to be_nil + key = DiasporaFederation.callbacks.trigger(:fetch_public_key_by_diaspora_id, remote_person.diaspora_handle) + expect(key).to be_a(OpenSSL::PKey::RSA) + expect(key.to_s).to eq(remote_person.serialized_public_key) end it "returns nil for an unknown person" do expect( - DiasporaFederation.callbacks.trigger(described_class, FactoryGirl.generate(:diaspora_id)) + DiasporaFederation.callbacks.trigger(:fetch_public_key_by_diaspora_id, FactoryGirl.generate(:diaspora_id)) ).to be_nil end end - describe :fetch_author_public_key_by_entity_guid do + describe ":fetch_author_public_key_by_entity_guid" do it "returns a public key for a known post" do - expect( - DiasporaFederation.callbacks.trigger(described_class, "Post", create_post_by_a_remote_person) - ).not_to be_nil + key = DiasporaFederation.callbacks.trigger(:fetch_author_public_key_by_entity_guid, + "Post", post_by_a_remote_person.guid) + expect(key).to be_a(OpenSSL::PKey::RSA) + expect(key.to_s).to eq(post_by_a_remote_person.author.serialized_public_key) end it "returns nil for an unknown post" do expect( - DiasporaFederation.callbacks.trigger(described_class, "Post", FactoryGirl.generate(:guid)) + DiasporaFederation.callbacks.trigger(:fetch_author_public_key_by_entity_guid, + "Post", FactoryGirl.generate(:guid)) ).to be_nil end end - describe :entity_author_is_local? do + describe ":entity_author_is_local?" do it "returns true for a post by a local user" do expect( - DiasporaFederation.callbacks.trigger(described_class, "Post", create_post_by_a_local_person) - ).to be(true) + DiasporaFederation.callbacks.trigger(:entity_author_is_local?, "Post", post_by_a_local_person.guid) + ).to be_truthy end it "returns false for a post by a remote user" do expect( - DiasporaFederation.callbacks.trigger(described_class, "Post", create_post_by_a_remote_person) - ).to be(false) + DiasporaFederation.callbacks.trigger(:entity_author_is_local?, "Post", post_by_a_remote_person.guid) + ).to be_falsey end it "returns false for a unknown post" do expect( - DiasporaFederation.callbacks.trigger(described_class, "Post", FactoryGirl.generate(:diaspora_id)) - ).to be(false) + DiasporaFederation.callbacks.trigger(:entity_author_is_local?, "Post", FactoryGirl.generate(:diaspora_id)) + ).to be_falsey end end - describe :fetch_entity_author_id_by_guid do + describe ":fetch_entity_author_id_by_guid" do it "returns id for a existing guid" do expect( - DiasporaFederation.callbacks.trigger(described_class, "Post", create_post_by_a_remote_person) - ).not_to be_nil + DiasporaFederation.callbacks.trigger(:fetch_entity_author_id_by_guid, "Post", post_by_a_remote_person.guid) + ).not_to eq(post_by_a_remote_person.author_id) end it "returns nil for a non-existing guid" do expect( - DiasporaFederation.callbacks.trigger(described_class, "Post", FactoryGirl.generate(:guid)) + DiasporaFederation.callbacks.trigger(:fetch_entity_author_id_by_guid, "Post", FactoryGirl.generate(:guid)) ).to be_nil end end