Sha256: 6bb173a1eeca9309e7decb8800e13205c219f3bf7eed240133d02cf57c04ff49
Contents?: true
Size: 2 KB
Versions: 33
Compression:
Stored size: 2 KB
Contents
# Copyright (C) 2009-2014 MongoDB Inc. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. require "spec_helper" describe Integer do describe "#to_bson" do context "when the integer is 32 bit" do let(:type) { 16.chr } let(:obj) { Integer::MAX_32BIT - 1 } let(:bson) { [ obj ].pack(BSON::Int32::PACK) } it_behaves_like "a serializable bson element" end context "when the integer is 64 bit" do let(:type) { 18.chr } let(:obj) { Integer::MAX_64BIT - 1 } let(:bson) { [ obj ].pack(BSON::Int64::PACK) } it_behaves_like "a serializable bson element" end context "when the integer is too large" do let(:integer) { Integer::MAX_64BIT + 1 } it "raises an out of range error" do expect { integer.to_bson }.to raise_error(RangeError) end end context "when the intger is too small" do let(:integer) { Integer::MIN_64BIT - 1 } it "raises an out of range error" do expect { integer.to_bson }.to raise_error(RangeError) end end end describe "#to_bson_key" do let(:obj) { Integer::MAX_32BIT - 1 } let(:encoded) { obj.to_s + BSON::NULL_BYTE } let(:previous_content) { 'previous_content'.force_encoding(BSON::BINARY) } it "returns the encoded string" do expect(obj.to_bson_key).to eq(encoded) end it "appends to optional previous content" do expect(obj.to_bson_key(previous_content)).to eq(previous_content << encoded) end end end
Version data entries
33 entries across 33 versions & 2 rubygems