Sha256: e790e68e26a533076a8b4c780bac4d3e1a0e0a0366f2c65e058f3becc031abae
Contents?: true
Size: 1.71 KB
Versions: 1
Compression:
Stored size: 1.71 KB
Contents
# frozen_string_literal: true require 'sinatra/base' # the FakeApi class is used to mock API requests while testing. class FakeApi < Sinatra::Base # resource post('/v2/resources') { json_response 201, 'resource.json' } get('/v2/resources/:id') { json_response 200, 'resource.json' } put('/v2/resources') { json_response 201, 'resource.json' } delete('/v2/resources/:id') { status 202 } # orders post('/v2/orders/valid_token') { json_response 200, 'order_token.json' } post('/v2/orders/invalid_token') { json_response 404, 'resource_not_found.json' } get('/v2/orders/:id') { json_response 200, 'resource.json' } # users get('/v2/users/valid_public_id') { json_response 200, 'user.json' } get('/v2/users/invalid_public_id') { json_response 404, 'resource_not_found.json' } put('/v2/users/valid_public_id') { status 204 } put('/v2/users/valid_public_id/password') { json_response 200, 'user.json' } put('/v2/users/invalid_public_id/password') { json_response 404, 'resource_not_found.json' } # session post('/v2/login') do request.body.rewind request_payload = JSON.parse request.body.read if request_payload['password'] == 'valid_password' json_response(200, 'user.json') else json_response(401, 'unauthorized.json') end end # relevance get('/v2/relevance/ruleset/names') { json_response 200, 'relevance_ruleset_names.json' } # errors get('/v2/client_error') { json_response 400, 'error.json' } get('/v2/server_error') { status 500 } get('/v2/proxy_error') { status 407 } private def json_response(response_code, file_name) content_type :json status response_code File.open(File.dirname(__FILE__) + '/fixtures/' + file_name, 'rb').read end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
finapps-2.0.17 | spec/support/fake_api.rb |