twitter-status-bot/.gems/gems/twitter-5.11.0/spec/twitter/place_spec.rb

169 lines
6.6 KiB
Ruby
Raw Normal View History

require 'helper'
describe Twitter::Place do
describe '.new' do
it 'raises an IndexError when id or woeid is not specified' do
expect { Twitter::Place.new(:id => 1) }.not_to raise_error
expect { Twitter::Place.new(:woeid => 1) }.not_to raise_error
expect { Twitter::Place.new }.to raise_error(IndexError)
end
end
describe '#eql?' do
it 'returns true when objects WOE IDs are the same' do
place = Twitter::Place.new(:woeid => 1, :name => 'foo')
other = Twitter::Place.new(:woeid => 1, :name => 'bar')
expect(place).to eql(other)
end
it 'returns false when objects WOE IDs are different' do
place = Twitter::Place.new(:woeid => 1)
other = Twitter::Place.new(:woeid => 2)
expect(place).not_to eql(other)
end
it 'returns false when classes are different' do
place = Twitter::Place.new(:woeid => 1)
other = Twitter::Base.new(:woeid => 1)
expect(place).not_to eql(other)
end
end
describe '#bounding_box' do
it 'returns a Twitter::Geo when bounding_box is set' do
place = Twitter::Place.new(:woeid => '247f43d441defc03', :bounding_box => {:type => 'Polygon', :coordinates => [[[-122.40348192, 37.77752898], [-122.387436, 37.77752898], [-122.387436, 37.79448597], [-122.40348192, 37.79448597]]]})
expect(place.bounding_box).to be_a Twitter::Geo::Polygon
end
it 'returns nil when not bounding_box is not set' do
place = Twitter::Place.new(:woeid => '247f43d441defc03')
expect(place.bounding_box).to be_nil
end
end
describe '#==' do
it 'returns true when objects WOE IDs are the same' do
place = Twitter::Place.new(:woeid => 1, :name => 'foo')
other = Twitter::Place.new(:woeid => 1, :name => 'bar')
expect(place == other).to be true
end
it 'returns false when objects WOE IDs are different' do
place = Twitter::Place.new(:woeid => 1)
other = Twitter::Place.new(:woeid => 2)
expect(place == other).to be false
end
it 'returns false when classes are different' do
place = Twitter::Place.new(:woeid => 1)
other = Twitter::Base.new(:woeid => 1)
expect(place == other).to be false
end
end
describe '#bounding_box' do
it 'returns a Twitter::Geo when bounding_box is set' do
place = Twitter::Place.new(:woeid => '247f43d441defc03', :bounding_box => {:type => 'Polygon', :coordinates => [[[-122.40348192, 37.77752898], [-122.387436, 37.77752898], [-122.387436, 37.79448597], [-122.40348192, 37.79448597]]]})
expect(place.bounding_box).to be_a Twitter::Geo::Polygon
end
it 'returns nil when not bounding_box is not set' do
place = Twitter::Place.new(:woeid => '247f43d441defc03')
expect(place.bounding_box).to be_nil
end
end
describe '#bounding_box?' do
it 'returns true when bounding_box is set' do
place = Twitter::Place.new(:woeid => '247f43d441defc03', :bounding_box => {:type => 'Polygon', :coordinates => [[[-122.40348192, 37.77752898], [-122.387436, 37.77752898], [-122.387436, 37.79448597], [-122.40348192, 37.79448597]]]})
expect(place.bounding_box?).to be true
end
it 'returns false when bounding_box is not set' do
place = Twitter::Place.new(:woeid => '247f43d441defc03')
expect(place.bounding_box?).to be false
end
end
describe '#contained_within' do
it 'returns a Twitter::Place when contained_within is set' do
place = Twitter::Place.new(:woeid => '247f43d441defc03', :contained_within => {:woeid => '247f43d441defc04'})
expect(place.contained_within).to be_a Twitter::Place
end
it 'returns nil when not contained_within is not set' do
place = Twitter::Place.new(:woeid => '247f43d441defc03')
expect(place.contained_within).to be_nil
end
end
describe '#contained_within?' do
it 'returns true when contained_within is set' do
place = Twitter::Place.new(:woeid => '247f43d441defc03', :contained_within => {:woeid => '247f43d441defc04'})
expect(place.contained?).to be true
end
it 'returns false when contained_within is not set' do
place = Twitter::Place.new(:woeid => '247f43d441defc03')
expect(place.contained?).to be false
end
end
describe '#country_code' do
it 'returns a country code when set with country_code' do
place = Twitter::Place.new(:woeid => '247f43d441defc03', :country_code => 'US')
expect(place.country_code).to eq('US')
end
it 'returns a country code when set with countryCode' do
place = Twitter::Place.new(:woeid => '247f43d441defc03', :countryCode => 'US') # rubocop:disable SymbolName
expect(place.country_code).to eq('US')
end
it 'returns nil when not set' do
place = Twitter::Place.new(:woeid => '247f43d441defc03')
expect(place.country_code).to be_nil
end
end
describe '#parent_id' do
it 'returns a parent ID when set with parentid' do
place = Twitter::Place.new(:woeid => '247f43d441defc03', :parentid => 1)
expect(place.parent_id).to eq(1)
end
it 'returns nil when not set' do
place = Twitter::Place.new(:woeid => '247f43d441defc03')
expect(place.parent_id).to be_nil
end
end
describe '#place_type' do
it 'returns a place type when set with place_type' do
place = Twitter::Place.new(:woeid => '247f43d441defc03', :place_type => 'city')
expect(place.place_type).to eq('city')
end
it 'returns a place type when set with placeType[name]' do
place = Twitter::Place.new(:woeid => '247f43d441defc03', :placeType => {:name => 'Town'}) # rubocop:disable SymbolName
expect(place.place_type).to eq('Town')
end
it 'returns nil when not set' do
place = Twitter::Place.new(:woeid => '247f43d441defc03')
expect(place.place_type).to be_nil
end
end
describe '#uri' do
it 'returns a URI when the url is set' do
place = Twitter::Place.new(:woeid => '247f43d441defc03', :url => 'https://api.twitter.com/1.1/geo/id/247f43d441defc03.json')
expect(place.uri).to be_an Addressable::URI
expect(place.uri.to_s).to eq('https://api.twitter.com/1.1/geo/id/247f43d441defc03.json')
end
it 'returns nil when the url is not set' do
place = Twitter::Place.new(:woeid => '247f43d441defc03')
expect(place.uri).to be_nil
end
end
describe '#uri?' do
it 'returns true when the url is set' do
place = Twitter::Place.new(:woeid => '247f43d441defc03', :url => 'https://api.twitter.com/1.1/geo/id/247f43d441defc03.json')
expect(place.uri?).to be true
end
it 'returns false when the url is not set' do
place = Twitter::Place.new(:woeid => '247f43d441defc03')
expect(place.uri?).to be false
end
end
end