From 970f5dd9cf4fe15c895568aec55b59e65c027f81 Mon Sep 17 00:00:00 2001 From: Chris Blanchard Date: Sun, 17 Apr 2016 00:05:18 +0100 Subject: [PATCH] Add teams api --- app/controllers/api/v1/teams_controller.rb | 23 ++++++++++++ config/routes.rb | 1 + .../api/v1/teams_controller_spec.rb | 35 +++++++++++++++++++ 3 files changed, 59 insertions(+) create mode 100644 app/controllers/api/v1/teams_controller.rb create mode 100644 spec/controllers/api/v1/teams_controller_spec.rb diff --git a/app/controllers/api/v1/teams_controller.rb b/app/controllers/api/v1/teams_controller.rb new file mode 100644 index 0000000..27479dc --- /dev/null +++ b/app/controllers/api/v1/teams_controller.rb @@ -0,0 +1,23 @@ +class Api::V1::TeamsController < Api::V1::BaseController + def index + render json: Api::V1::UsersCollection.as_json + end + + def show + @team = Team.find params[:id] + render json: { + id: @team.id, + name: @team.name, + logo: @team.logo, + members: @team.teamers.active.map do |m| + { + id: m.user.id, + username: m.user.username, + steamid: m.user.steamid + } + end + } + rescue ActiveRecord::RecordNotFound + raise ActionController::RoutingError.new("User Not Found") + end +end diff --git a/config/routes.rb b/config/routes.rb index 80f0f11..d1d98fb 100755 --- a/config/routes.rb +++ b/config/routes.rb @@ -6,6 +6,7 @@ Ensl::Application.routes.draw do namespace :api do namespace :v1 do resources :users, only: [:show, :index] + resources :teams, only: [:show] resources :servers, only: [:index] resources :maps, only: [:index] end diff --git a/spec/controllers/api/v1/teams_controller_spec.rb b/spec/controllers/api/v1/teams_controller_spec.rb new file mode 100644 index 0000000..2388787 --- /dev/null +++ b/spec/controllers/api/v1/teams_controller_spec.rb @@ -0,0 +1,35 @@ +require "spec_helper" + +describe Api::V1::TeamsController do + before do + request.accept = "application/json" + end + + describe "#show" do + before(:each) do + @founder = create :user + @team_member = create :user + @ex_team_member = create :user + @team = create :team, founder: @founder + Teamer.create user: @team_member, team: @team, rank: Teamer::RANK_MEMBER + Teamer.create user: @ex_team_member, team: @team, rank: Teamer::RANK_REMOVED + end + + it "returns team data" do + get :show, id: @team.id + expect(response).to be_success + expect(json["id"]).to eq(@team.id) + expect(json["name"]).to eq(@team.name) + + json["members"].each do |member| + expect(@team.teamers.active.map(&:user_id)).to include(member["id"]) + end + end + + it "returns 404 if team not found" do + expect { + get :show, id: Team.last.id + 1 + }.to raise_error(ActionController::RoutingError) + end + end +end