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