Skip to content
This repository has been archived by the owner on Nov 8, 2024. It is now read-only.

Commit

Permalink
feat: styleguide push
Browse files Browse the repository at this point in the history
  • Loading branch information
Tully committed Apr 9, 2018
1 parent 132ef79 commit 56c7e71
Show file tree
Hide file tree
Showing 5 changed files with 80 additions and 7 deletions.
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -132,6 +132,7 @@ Usage:
Options:
[--fetch], [--no-fetch] # Fetch styleguide rules and functions from apiary.io
[--push], [--no-push] # Push styleguide rules and functions to apiary.io
[--add=ADD] # Path to API Description Document. When given a directory, it will look for `apiary.apib` and `swagger.yaml` file
[--functions=FUNCTIONS] # Path to to the file with functions definitions
[--rules=RULES] # Path to to the file with rules definitions - `functions.js` and `rules.json` are loaded if not specified
Expand Down
1 change: 1 addition & 0 deletions lib/apiary/cli.rb
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@ def publish

desc 'styleguide', 'Check API Description Document against styleguide rules (Apiary.io pro plan is required - https://apiary.io/plans )'
method_option :fetch, type: :boolean, desc: 'Fetch styleguide rules and functions from apiary.io'
method_option :push, type: :boolean, desc: 'Push styleguide rules and functions to apiary.io'
method_option :add, type: :string, desc: 'Path to API Description Document. When given a directory, it will look for `apiary.apib` and `swagger.yaml` file'
method_option :functions, type: :string, desc: 'Path to to the file with functions definitions'
method_option :rules, type: :string, desc: 'Path to to the file with rules definitions - `functions.js` and `rules.json` are loaded if not specified'
Expand Down
38 changes: 32 additions & 6 deletions lib/apiary/command/styleguide.rb
Original file line number Diff line number Diff line change
Expand Up @@ -36,11 +36,37 @@ def execute
check_api_key
if @options.fetch
fetch
elsif @options.push
push
else
validate
end
end

def push
begin
load(false, true, true)
rescue StandardError => e
abort "Error: #{e.message}"
end

path = 'styleguide-cli/set-assertions/'
headers = @options.headers.clone
headers[:authentication] = "Token #{@options.api_key}"

data = {
functions: @functions,
rules: @rules,
}.to_json

begin
call_apiary(path, data, headers, :post)
rescue => e
puts e
abort "Error: Can not write into the rules/functions file: #{e}"
end
end

def fetch
begin
assertions = fetch_from_apiary
Expand Down Expand Up @@ -68,7 +94,7 @@ def validate
end

begin
load
load(true, true, true)
rescue StandardError => e
abort "Error: #{e.message}"
end
Expand Down Expand Up @@ -196,11 +222,11 @@ def check_api_key
abort 'Error: API key must be provided through environment variable APIARY_API_KEY. \Please go to https://login.apiary.io/tokens to obtain it.'
end

def load
@add_path = api_description_source_path(@options.add)
@add = api_description_source(@add_path)
@functions = get_functions(@options.functions)
@rules = get_rules(@options.rules)
def load(add, functions, rules)
@add_path = api_description_source_path(@options.add) if add
@add = api_description_source(@add_path) if add
@functions = get_functions(@options.functions) if functions
@rules = get_rules(@options.rules) if rules
end

def fetch_from_apiary
Expand Down
2 changes: 1 addition & 1 deletion lib/apiary/version.rb
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
module Apiary
VERSION = '0.10.3'.freeze
VERSION = '0.11.3'.freeze
end
45 changes: 45 additions & 0 deletions spec/apiary/command/styleguide_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -172,4 +172,49 @@ def test_abort(command, message)
end.to output("[\n\n]\n").to_stdout
end
end

describe 'push' do
it 'call command without APIARY_API_KEY set' do
opts = {
push: true,
api_key: '',
functions: 'features/support',
rules: 'features/support'
}
command = Apiary::Command::Styleguide.new(opts)
test_abort(command, 'Error: API key must be provided through environment variable APIARY_API_KEY.')
end

it 'call command with incorrect APIARY_API_KEY' do
opts = {
push: true,
api_key: 'xxx'
}

command = Apiary::Command::Styleguide.new(opts)
stub_request(:post, "https://#{command.options.api_host}/styleguide-cli/set-assertions/").to_return(status: [403, 'This resource requires authenticated API call.'])

test_abort(command, 'Error: Apiary service responded with: 403')
end

it 'call command with correct APIARY_API_KEY' do
opts = {
push: true,
api_key: 'xxx',
functions: 'function testFunction(data) { return "failed"; }',
rules: '[{"ruleName": "testName","functionName": "testFunction","target": "Request_Body","intent": "testIntent"}]'
}

command = Apiary::Command::Styleguide.new(opts)
body = "{\"functions\":\"/*\\r\\n @targets: API_Name\\r\\n */\\r\\n\\r\\nfunction validateApiName(apiName) {\\r\\n return true;\\r\\n};\\r\\n\",\"rules\":[{\"intent\":\"validateApiName\",\"target\":\"API_Name\",\"functionName\":\"validateApiName\",\"ruleName\":\"validateApiName\"}]}"
stub_request(:post, "https://#{command.options.api_host}/styleguide-cli/set-assertions/").to_return(status: 200, body: '')

expect do
begin
command.execute
rescue SystemExit
end
end.to output("").to_stdout
end
end
end

0 comments on commit 56c7e71

Please sign in to comment.