Skip to content

Commit

Permalink
Why : Ruby 1.9 dosent support hash params for a method & string to sy…
Browse files Browse the repository at this point in the history
…mbol keys

What : Reverting these
  • Loading branch information
Edwin Rozario committed Jan 29, 2018
1 parent d20b5d6 commit c17bd5a
Show file tree
Hide file tree
Showing 5 changed files with 24 additions and 31 deletions.
2 changes: 1 addition & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
# Changelog

## 0.3.8
* Major version change as new class added handle request.
* Major version change as new class added to handle request.
* Classes separated in different files.
* Syntax for Hashes changed from hashrockets to symbol.
* Alias for request methods defined to match HTTP methods
Expand Down
18 changes: 6 additions & 12 deletions lib/firebase/client.rb
Original file line number Diff line number Diff line change
Expand Up @@ -6,43 +6,37 @@ class Client
attr_reader :request

def initialize(base_uri, auth = nil)
@request = Request.new(uri: base_uri,
auth: auth)
@request = Request.new(base_uri, auth)
end

# Writes and returns the data
# Firebase.set('users/info', { 'name' => 'Oscar' }) => { 'name' => 'Oscar' }
def set(path, data, query = {})
request.execute(method: :put, path: path,
data: data, query: query)
request.execute(:put, path, data, query)
end

# Returns the data at path
def get(path, query = {})
request.execute(method: :get, path: path,
query: query)
request.execute(:get, path, nil, query)
end

# Writes the data, returns the key name of the data added
# Firebase.push('users', { 'age' => 18}) => {"name":"-INOQPH-aV_psbk3ZXEX"}
def push(path, data, query = {})
request.execute(method: :post, path: path,
data: data, query: query)
request.execute(:post, path, data, query)
end

# Deletes the data at path and returs true
def delete(path, query = {})
request.execute(method: :delete, path: path,
query: query)
request.execute(:delete, path, nil, query)
end

# Write the data at path but does not delete ommited
# children. Returns the data
# Firebase.update('users/info',
# { 'name' => 'Oscar' }) => { 'name' => 'Oscar' }
def update(path, data, query = {})
request.execute(method: :patch, path: path,
data: data, query: query)
request.execute(:patch, path, data, query)
end

# Aliasing methods to match usual Ruby/Rails http methods
Expand Down
4 changes: 2 additions & 2 deletions lib/firebase/request.rb
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ module Firebase
class Request
attr_reader :http_client, :auth

def initialize(uri:, auth:, headers: { 'Content-Type': 'application/json' })
def initialize(uri, auth, headers = { 'Content-Type' => 'application/json' })
raise ArgumentError.new('base_uri must be a valid https uri') if uri !~ URI.regexp(%w(https))
uri += '/' unless uri.end_with?('/')

Expand All @@ -32,7 +32,7 @@ def initialize(uri:, auth:, headers: { 'Content-Type': 'application/json' })
end
end

def execute(method:, path:, data: nil, query: {})
def execute(method, path, data = nil, query = {})
raise ArgumentError.new("Invalid path: #{path}. Path must be relative") if path.start_with? '/'

if @expires_at && Time.now > @expires_at
Expand Down
29 changes: 14 additions & 15 deletions spec/firebase_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@
end

it 'returns default header' do
expect(@firebase.request.http_client.default_header).to eq({ 'Content-Type': 'application/json'})
expect(@firebase.request.http_client.default_header).to eq('Content-Type' => 'application/json')
end

it 'returns base_url' do
Expand All @@ -53,19 +53,19 @@

describe 'set' do
it 'writes and returns the data' do
expect(@firebase.request).to receive(:execute).with(method: :put, path: 'users/info', data: data, query: {})
expect(@firebase.request).to receive(:execute).with(:put, 'users/info', data, {})
@firebase.set('users/info', data)
end

it 'writes and returns the data' do
expect(@firebase.request).to receive(:execute).with(method: :put, path: 'users/info', data: data, query: {})
expect(@firebase.request).to receive(:execute).with(:put, 'users/info', data, {})
@firebase.put('users/info', data)
end
end

describe "get" do
it "returns the data" do
expect(@firebase.request).to receive(:execute).with(method: :get, path: 'users/info', query: {})
expect(@firebase.request).to receive(:execute).with(:get, 'users/info', nil, {})
@firebase.get('users/info')
end

Expand All @@ -74,7 +74,7 @@
:orderBy => '"$key"',
:startAt => '"A1"'
}
expect(@firebase.request).to receive(:execute).with(method: :get, path: 'users/info', query: params)
expect(@firebase.request).to receive(:execute).with(:get, 'users/info', nil, params)
@firebase.get('users/info', params)
end

Expand Down Expand Up @@ -136,31 +136,31 @@

describe 'push/post' do
it 'writes the data' do
expect(@firebase.request).to receive(:execute).with(method: :post, path: 'users', data: data, query: {})
expect(@firebase.request).to receive(:execute).with(:post, 'users', data, {})
@firebase.push('users', data)
end

it 'writes the data' do
expect(@firebase.request).to receive(:execute).with(method: :post, path: 'users', data: data, query: {})
expect(@firebase.request).to receive(:execute).with(:post, 'users', data, {})
@firebase.post('users', data)
end
end

describe 'delete/destroy' do
it 'returns true' do
expect(@firebase.request).to receive(:execute).with(method: :delete, path: 'users/info', query: {})
expect(@firebase.request).to receive(:execute).with(:delete, 'users/info', nil, {})
@firebase.delete('users/info')
end

it 'returns true' do
expect(@firebase.request).to receive(:execute).with(method: :delete, path: 'users/info', query: {})
expect(@firebase.request).to receive(:execute).with(:delete, 'users/info', nil, {})
@firebase.destroy('users/info')
end
end

describe "update" do
it "updates and returns the data" do
expect(@firebase.request).to receive(:execute).with(method: :patch, path: 'users/info', data: data, query: {})
expect(@firebase.request).to receive(:execute).with(:patch, 'users/info', data, {})
@firebase.update('users/info', data)
end
end
Expand Down Expand Up @@ -198,7 +198,7 @@
it "sets custom auth header" do
client = Firebase::Client.new('https://test.firebaseio.com/', '{ "private_key": true }')

expect(client.request.http_client.default_header).to eql('Content-Type': 'application/json', authorization: 'Bearer 1')
expect(client.request.http_client.default_header).to eql('Content-Type' => 'application/json', authorization: 'Bearer 1')
end

it "handles token expiry" do
Expand All @@ -209,10 +209,9 @@

client.get 'dummy'

expect(client.request.http_client.default_header).to eql({
'Content-Type': 'application/json',
authorization: 'Bearer 2'
})
expect(client.request.http_client.default_header).to eql(
'Content-Type' => 'application/json',
authorization: 'Bearer 2')
end
end
end
2 changes: 1 addition & 1 deletion spec/spec_helper.rb
Original file line number Diff line number Diff line change
Expand Up @@ -8,4 +8,4 @@
# in ./support/ and its subdirectories.
Dir["#{File.dirname(__FILE__)}/support/**/*.rb"].each {|f| require f}

RSpec.configure do |config|; end
RSpec.configure do |config|; end

0 comments on commit c17bd5a

Please sign in to comment.