Commit 14f2a5e86d828daf6b25fe8b7fc68e125848c0e4
1 parent
8a6d7d69
Exists in
theme-brasil-digital-from-staging
and in
9 other branches
Fix merge with api
Showing
3 changed files
with
0 additions
and
119 deletions
Show diff stats
Gemfile
| ... | ... | @@ -13,7 +13,6 @@ gem 'daemons', '~> 1.1.5' |
| 13 | 13 | gem 'thin', '~> 1.3.1' |
| 14 | 14 | gem 'nokogiri', '~> 1.5.5' |
| 15 | 15 | gem 'rake', :require => false |
| 16 | -gem 'grape', '~> 0.2.1' | |
| 17 | 16 | gem 'rest-client', '~> 1.6.7' |
| 18 | 17 | gem 'exception_notification', '~> 4.0.1' |
| 19 | 18 | gem 'gettext', '~> 2.2.1', :require => false | ... | ... |
db/migrate/20140407013817_add_private_token_info_to_users.rb
| ... | ... | @@ -1,11 +0,0 @@ |
| 1 | -class AddPrivateTokenInfoToUsers < ActiveRecord::Migration | |
| 2 | - def self.up | |
| 3 | - add_column :users, :private_token, :string | |
| 4 | - add_column :users, :private_token_generated_at, :datetime | |
| 5 | - end | |
| 6 | - | |
| 7 | - def self.down | |
| 8 | - remove_column :users, :private_token | |
| 9 | - remove_column :users, :private_token_generated_at | |
| 10 | - end | |
| 11 | -end |
test/unit/api_test.rb
| ... | ... | @@ -1,107 +0,0 @@ |
| 1 | -require File.dirname(__FILE__) + '/../test_helper' | |
| 2 | - | |
| 3 | -class APITest < ActiveSupport::TestCase | |
| 4 | - | |
| 5 | - include Rack::Test::Methods | |
| 6 | - | |
| 7 | - def app | |
| 8 | - API::API | |
| 9 | - end | |
| 10 | - | |
| 11 | - def setup | |
| 12 | - @user = User.create!(:login => 'testapi', :password => 'testapi', :password_confirmation => 'testapi', :email => 'test@test.org', :environment => Environment.default) | |
| 13 | - @user.activate | |
| 14 | - | |
| 15 | - post "/api/v1/login?login=testapi&password=testapi" | |
| 16 | - json = JSON.parse(last_response.body) | |
| 17 | - @private_token = json["private_token"] | |
| 18 | - @params = {:private_token => @private_token} | |
| 19 | - end | |
| 20 | - attr_accessor :private_token, :user, :params | |
| 21 | - | |
| 22 | - should 'generate private token when login' do | |
| 23 | - params = {:login => "testapi", :password => "testapi"} | |
| 24 | - post "/api/v1/login?#{params.to_query}" | |
| 25 | - json = JSON.parse(last_response.body) | |
| 26 | - assert !json["private_token"].blank? | |
| 27 | - end | |
| 28 | - | |
| 29 | - should 'return 401 when login fails' do | |
| 30 | - user.destroy | |
| 31 | - params = {:login => "testapi", :password => "testapi"} | |
| 32 | - post "/api/v1/login?#{params.to_query}" | |
| 33 | - assert_equal 401, last_response.status | |
| 34 | - end | |
| 35 | - | |
| 36 | - should 'register a user' do | |
| 37 | - params = {:login => "newuserapi", :password => "newuserapi", :email => "newuserapi@email.com" } | |
| 38 | - post "/api/v1/register?#{params.to_query}" | |
| 39 | - assert_equal 201, last_response.status | |
| 40 | - end | |
| 41 | - | |
| 42 | - should 'do not register a user without email' do | |
| 43 | - params = {:login => "newuserapi", :password => "newuserapi", :email => nil } | |
| 44 | - post "/api/v1/register?#{params.to_query}" | |
| 45 | - assert_equal 400, last_response.status | |
| 46 | - end | |
| 47 | - | |
| 48 | - should 'do not register a duplicated user' do | |
| 49 | - params = {:login => "newuserapi", :password => "newuserapi", :email => "newuserapi@email.com" } | |
| 50 | - post "/api/v1/register?#{params.to_query}" | |
| 51 | - post "/api/v1/register?#{params.to_query}" | |
| 52 | - assert_equal 400, last_response.status | |
| 53 | - end | |
| 54 | - | |
| 55 | - should 'list articles' do | |
| 56 | - article = fast_create(Article, :profile_id => user.person.id, :name => "Some thing") | |
| 57 | - get "/api/v1/articles/?#{params.to_query}" | |
| 58 | - json = JSON.parse(last_response.body) | |
| 59 | - assert_includes json["articles"].map { |a| a["id"] }, article.id | |
| 60 | - end | |
| 61 | - | |
| 62 | - should 'return article by id' do | |
| 63 | - article = fast_create(Article, :profile_id => user.person.id, :name => "Some thing") | |
| 64 | - get "/api/v1/articles/#{article.id}?#{params.to_query}" | |
| 65 | - json = JSON.parse(last_response.body) | |
| 66 | - assert_equal article.id, json["article"]["id"] | |
| 67 | - end | |
| 68 | - | |
| 69 | - should 'return comments of an article' do | |
| 70 | - article = fast_create(Article, :profile_id => user.person.id, :name => "Some thing") | |
| 71 | - article.comments.create!(:body => "some comment", :author => user.person) | |
| 72 | - article.comments.create!(:body => "another comment", :author => user.person) | |
| 73 | - | |
| 74 | - get "/api/v1/articles/#{article.id}/comments?#{params.to_query}" | |
| 75 | - json = JSON.parse(last_response.body) | |
| 76 | - assert_equal 2, json["comments"].length | |
| 77 | - end | |
| 78 | - | |
| 79 | - should 'list users' do | |
| 80 | - get "/api/v1/users/?#{params.to_query}" | |
| 81 | - json = JSON.parse(last_response.body) | |
| 82 | - assert_includes json["users"].map { |a| a["login"] }, user.login | |
| 83 | - end | |
| 84 | - | |
| 85 | - should 'list user permissions' do | |
| 86 | - community = fast_create(Community) | |
| 87 | - community.add_admin(user.person) | |
| 88 | - get "/api/v1/users/#{user.id}/?#{params.to_query}" | |
| 89 | - json = JSON.parse(last_response.body) | |
| 90 | - assert_includes json["user"]["permissions"], community.identifier | |
| 91 | - end | |
| 92 | - | |
| 93 | - should 'list categories' do | |
| 94 | - category = fast_create(Category) | |
| 95 | - get "/api/v1/categories/?#{params.to_query}" | |
| 96 | - json = JSON.parse(last_response.body) | |
| 97 | - assert_includes json["categories"].map { |c| c["name"] }, category.name | |
| 98 | - end | |
| 99 | - | |
| 100 | - should 'get category by id' do | |
| 101 | - category = fast_create(Category) | |
| 102 | - get "/api/v1/categories/#{category.id}/?#{params.to_query}" | |
| 103 | - json = JSON.parse(last_response.body) | |
| 104 | - assert_equal category.name, json["category"]["name"] | |
| 105 | - end | |
| 106 | - | |
| 107 | -end |