Sha256: 07291633a09743f2ebfd62233a3474e7a080306f125e8d0c1125df69ffbb61fa

Contents?: true

Size: 1.89 KB

Versions: 26

Compression:

Stored size: 1.89 KB

Contents

require 'spec_helper'
require 'riak/stamp'

describe Riak::Stamp do
  subject { described_class.new(Riak::Client.new) }
  it "should generate always increasing integer identifiers" do
    1000.times do
      one = subject.next
      two = subject.next
      [one, two].should be_all {|i| Integer === i }
      two.should > one
    end
  end

  it "should delay until the next millisecond when the sequence overflows" do
    old = subject.instance_variable_get(:@timestamp) + 0
    subject.instance_variable_set(:@sequence, described_class::SEQUENCE_MASK)
    count = 0
    # Simulate the time_gen method returning the same thing multiple times
    subject.stub(:time_gen) do
      count += 1
      if count < 10
        old
      else
        old + 1
      end
    end
    ((subject.next >> described_class::TIMESTAMP_SHIFT) & described_class::TIMESTAMP_MASK).should == old + 1
  end

  it "should raise an exception when the system clock moves backwards" do
    old = subject.instance_variable_get(:@timestamp)
    subject.should_receive(:time_gen).and_return(old - 10)
    expect {
      subject.next
    }.to raise_error(Riak::BackwardsClockError)
  end

  # The client/worker ID should be used for disambiguation, not for
  # primary ordering.  This breaks from the Snowflake model where the
  # worker ID is in more significant bits.
  it "should use the client ID as the bottom component of the identifier" do
    (subject.next & described_class::CLIENT_ID_MASK).should == subject.client.client_id & described_class::CLIENT_ID_MASK
  end

  context "using a non-integer client ID" do
    subject { described_class.new(Riak::Client.new(:client_id => "ripple")) }
    let(:hash) { "ripple".hash }

    it "should use the hash of the client ID as the bottom component of the identifier" do
      (subject.next & described_class::CLIENT_ID_MASK).should == subject.client.client_id.hash & described_class::CLIENT_ID_MASK
    end
  end
end

Version data entries

26 entries across 16 versions & 2 rubygems

Version Path
riak-client-1.0.2 pkg/riak-client-1.0.1/spec/riak/stamp_spec.rb
riak-client-1.0.2 spec/riak/stamp_spec.rb
riak-client-1.0.2 pkg/riak-client-1.0.1/pkg/riak-client-1.0.0/spec/riak/stamp_spec.rb
riak-client-1.0.0 spec/riak/stamp_spec.rb
seomoz-riak-client-1.0.0.pre spec/riak/stamp_spec.rb
riak-client-1.0.0.beta spec/riak/stamp_spec.rb