Sha256: 10b94cf7af56e687923810282c020d92e0c4d27f0fc6820bc69c76cd57052353

Contents?: true

Size: 1.95 KB

Versions: 2

Compression:

Stored size: 1.95 KB

Contents

require 'spec_helper'

describe Keen::ScopedKey do
  let(:api_key) { "ab428324dbdbcfe744" }
  let(:bad_api_key) { "badbadbadbad" }
  let(:data) { {
   "filters" => [{
      "property_name" => "accountId",
      "operator" => "eq",
      "property_value" => "123456"
    }]
  }}
  let(:new_scoped_key) { Keen::ScopedKey.new(api_key, data) }

  describe "constructor" do
    it "should retain the api_key" do
      expect(new_scoped_key.api_key).to eq(api_key)
    end

    it "should retain the data" do
      expect(new_scoped_key.data).to eq(data)
    end
  end

  describe "encrypt! and decrypt!" do
    it "should encrypt and hex encode the data using the api key" do
      encrypted_str = new_scoped_key.encrypt!
      other_api_key = Keen::ScopedKey.decrypt!(api_key, encrypted_str)
      expect(other_api_key.data).to eq(data)
    end

    describe "when an IV is not provided" do
      it "should not produce the same encrypted key text" do
        expect(new_scoped_key.encrypt!).to_not eq(new_scoped_key.encrypt!)
      end
    end

    describe "when an IV is provided" do
      it "should produce the same encrypted key text for a " do
        iv = "\0" * 16
        expect(new_scoped_key.encrypt!(iv)).to eq(new_scoped_key.encrypt!(iv))
      end

      it "should raise error when an invalid IV is supplied" do
        iv = "fakeiv"
        expect { new_scoped_key.encrypt!(iv) }.to raise_error(OpenSSL::Cipher::CipherError)
      end
    end

    it "should not decrypt the scoped key with a bad api key" do
      encrypted_str = new_scoped_key.encrypt!
      expect {
        other_api_key = Keen::ScopedKey.decrypt!(bad_api_key, encrypted_str)
      }.to raise_error(OpenSSL::Cipher::CipherError)
    end

    it "should properly encrypt with master keys that are 32 characters long" do
       master_key = "\0" * 32
       scoped_key = Keen::ScopedKey.new(master_key, data).encrypt!
       Keen::ScopedKey.decrypt!(master_key, scoped_key).data.should == data
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
keen-0.9.10 spec/keen/scoped_key_old_spec.rb
keen-0.9.9 spec/keen/scoped_key_old_spec.rb