mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2025-09-05 20:54:27 +08:00
Merge pull request #1262 from okriuchykhin/ok_SCI_2614
Add read inventories and inventory items endpoints [SCI-2614][SCI-2616][SCI-2617]
This commit is contained in:
commit
1832c0e806
26 changed files with 464 additions and 20 deletions
|
@ -3,7 +3,7 @@ AllCops:
|
||||||
- "vendor/**/*"
|
- "vendor/**/*"
|
||||||
- "db/schema.rb"
|
- "db/schema.rb"
|
||||||
UseCache: false
|
UseCache: false
|
||||||
TargetRubyVersion: 2.2
|
TargetRubyVersion: 2.4
|
||||||
|
|
||||||
##################### Style ####################################
|
##################### Style ####################################
|
||||||
|
|
||||||
|
|
1
Gemfile
1
Gemfile
|
@ -51,7 +51,6 @@ gem 'rgl' # Graph framework for project diagram calculations
|
||||||
gem 'nested_form_fields'
|
gem 'nested_form_fields'
|
||||||
gem 'ajax-datatables-rails', '~> 0.3.1'
|
gem 'ajax-datatables-rails', '~> 0.3.1'
|
||||||
gem 'commit_param_routing' # Enables different submit actions in the same form to route to different actions in controller
|
gem 'commit_param_routing' # Enables different submit actions in the same form to route to different actions in controller
|
||||||
gem 'kaminari'
|
|
||||||
gem 'i18n-js', '~> 3.0' # Localization in javascript files
|
gem 'i18n-js', '~> 3.0' # Localization in javascript files
|
||||||
gem 'roo', '~> 2.7.1' # Spreadsheet parser
|
gem 'roo', '~> 2.7.1' # Spreadsheet parser
|
||||||
gem 'wicked_pdf', '~> 1.1.0'
|
gem 'wicked_pdf', '~> 1.1.0'
|
||||||
|
|
|
@ -1,3 +1,5 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
module Api
|
module Api
|
||||||
class ApiController < ActionController::API
|
class ApiController < ActionController::API
|
||||||
attr_reader :iss
|
attr_reader :iss
|
||||||
|
@ -50,7 +52,7 @@ module Api
|
||||||
def authenticate
|
def authenticate
|
||||||
if auth_params[:grant_type] == 'password'
|
if auth_params[:grant_type] == 'password'
|
||||||
user = User.find_by_email(auth_params[:email])
|
user = User.find_by_email(auth_params[:email])
|
||||||
unless user && user.valid_password?(auth_params[:password])
|
unless user&.valid_password?(auth_params[:password])
|
||||||
raise StandardError, 'Default: Wrong user password'
|
raise StandardError, 'Default: Wrong user password'
|
||||||
end
|
end
|
||||||
payload = { user_id: user.id }
|
payload = { user_id: user.id }
|
||||||
|
|
|
@ -1,3 +1,5 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
module Api
|
module Api
|
||||||
module V1
|
module V1
|
||||||
class BaseController < ApiController
|
class BaseController < ApiController
|
||||||
|
|
31
app/controllers/api/v1/inventories_controller.rb
Normal file
31
app/controllers/api/v1/inventories_controller.rb
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
module Api
|
||||||
|
module V1
|
||||||
|
class InventoriesController < BaseController
|
||||||
|
before_action :load_team, only: %i(show index)
|
||||||
|
before_action :load_inventory, only: %i(show)
|
||||||
|
|
||||||
|
def index
|
||||||
|
inventories =
|
||||||
|
@team.repositories.page(params[:page]).per(params[:page_size])
|
||||||
|
render json: inventories, each_serializer: InventorySerializer
|
||||||
|
end
|
||||||
|
|
||||||
|
def show
|
||||||
|
render json: @inventory, serializer: InventorySerializer
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def load_team
|
||||||
|
@team = Team.find(params.require(:team_id))
|
||||||
|
return render json: {}, status: :forbidden unless can_read_team?(@team)
|
||||||
|
end
|
||||||
|
|
||||||
|
def load_inventory
|
||||||
|
@inventory = @team.repositories.find(params.require(:id))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
34
app/controllers/api/v1/inventory_items_controller.rb
Normal file
34
app/controllers/api/v1/inventory_items_controller.rb
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
module Api
|
||||||
|
module V1
|
||||||
|
class InventoryItemsController < BaseController
|
||||||
|
before_action :load_team
|
||||||
|
before_action :load_inventory
|
||||||
|
|
||||||
|
def index
|
||||||
|
items =
|
||||||
|
@inventory.repository_rows
|
||||||
|
.includes(repository_cells: :repository_column)
|
||||||
|
.includes(
|
||||||
|
repository_cells: Extends::REPOSITORY_SEARCH_INCLUDES
|
||||||
|
).page(params[:page])
|
||||||
|
.per(params[:page_size])
|
||||||
|
render json: items,
|
||||||
|
each_serializer: InventoryItemSerializer,
|
||||||
|
include: :inventory_cells
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def load_team
|
||||||
|
@team = Team.find(params.require(:team_id))
|
||||||
|
return render json: {}, status: :forbidden unless can_read_team?(@team)
|
||||||
|
end
|
||||||
|
|
||||||
|
def load_inventory
|
||||||
|
@inventory = @team.repositories.find(params.require(:inventory_id))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -16,7 +16,6 @@ module Api
|
||||||
|
|
||||||
def load_team
|
def load_team
|
||||||
@team = Team.find(params.require(:id))
|
@team = Team.find(params.require(:id))
|
||||||
return render json: {}, status: :not_found unless @team
|
|
||||||
return render json: {}, status: :forbidden unless can_read_team?(@team)
|
return render json: {}, status: :forbidden unless can_read_team?(@team)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -8,22 +8,26 @@ class RepositoryCell < ActiveRecord::Base
|
||||||
dependent: :destroy
|
dependent: :destroy
|
||||||
belongs_to :repository_text_value,
|
belongs_to :repository_text_value,
|
||||||
(lambda do
|
(lambda do
|
||||||
where(repository_cells: { value_type: 'RepositoryTextValue' })
|
includes(:repository_cell)
|
||||||
|
.where(repository_cells: { value_type: 'RepositoryTextValue' })
|
||||||
end),
|
end),
|
||||||
optional: true, foreign_key: :value_id
|
optional: true, foreign_key: :value_id
|
||||||
belongs_to :repository_date_value,
|
belongs_to :repository_date_value,
|
||||||
(lambda do
|
(lambda do
|
||||||
where(repository_cells: { value_type: 'RepositoryDateValue' })
|
includes(:repository_cell)
|
||||||
|
.where(repository_cells: { value_type: 'RepositoryDateValue' })
|
||||||
end),
|
end),
|
||||||
optional: true, foreign_key: :value_id
|
optional: true, foreign_key: :value_id
|
||||||
belongs_to :repository_list_value,
|
belongs_to :repository_list_value,
|
||||||
(lambda do
|
(lambda do
|
||||||
where(repository_cells: { value_type: 'RepositoryListValue' })
|
includes(:repository_cell)
|
||||||
|
.where(repository_cells: { value_type: 'RepositoryListValue' })
|
||||||
end),
|
end),
|
||||||
optional: true, foreign_key: :value_id
|
optional: true, foreign_key: :value_id
|
||||||
belongs_to :repository_asset_value,
|
belongs_to :repository_asset_value,
|
||||||
(lambda do
|
(lambda do
|
||||||
where(repository_cells: { value_type: 'RepositoryAssetValue' })
|
includes(:repository_cell)
|
||||||
|
.where(repository_cells: { value_type: 'RepositoryAssetValue' })
|
||||||
end),
|
end),
|
||||||
optional: true, foreign_key: :value_id
|
optional: true, foreign_key: :value_id
|
||||||
|
|
||||||
|
|
|
@ -10,7 +10,7 @@ class RepositoryRow < ApplicationRecord
|
||||||
foreign_key: :last_modified_by_id,
|
foreign_key: :last_modified_by_id,
|
||||||
class_name: 'User',
|
class_name: 'User',
|
||||||
optional: true
|
optional: true
|
||||||
has_many :repository_cells, dependent: :destroy
|
has_many :repository_cells, -> { order(:id) }, dependent: :destroy
|
||||||
has_many :repository_columns, through: :repository_cells
|
has_many :repository_columns, through: :repository_cells
|
||||||
has_many :my_module_repository_rows,
|
has_many :my_module_repository_rows,
|
||||||
inverse_of: :repository_row, dependent: :destroy
|
inverse_of: :repository_row, dependent: :destroy
|
||||||
|
|
36
app/serializers/api/v1/inventory_cell_serializer.rb
Normal file
36
app/serializers/api/v1/inventory_cell_serializer.rb
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
module Api
|
||||||
|
module V1
|
||||||
|
class InventoryCellSerializer < ActiveModel::Serializer
|
||||||
|
type :inventory_cells
|
||||||
|
attributes :id, :data_type, :data
|
||||||
|
attribute :repository_column_id, key: :column_id
|
||||||
|
|
||||||
|
def data_type
|
||||||
|
type_id = RepositoryColumn
|
||||||
|
.data_types[object.repository_column.data_type]
|
||||||
|
I18n.t("api.v1.inventory_data_types.t#{type_id}")
|
||||||
|
end
|
||||||
|
|
||||||
|
def data
|
||||||
|
value =
|
||||||
|
case object.value_type
|
||||||
|
when 'RepositoryTextValue'
|
||||||
|
object.repository_text_value
|
||||||
|
when 'RepositoryDateValue'
|
||||||
|
object.repository_date_value
|
||||||
|
when 'RepositoryListValue'
|
||||||
|
object.repository_list_value
|
||||||
|
when 'RepositoryAssetValue'
|
||||||
|
object.repository_list_value
|
||||||
|
end
|
||||||
|
ActiveModelSerializers::SerializableResource.new(
|
||||||
|
value,
|
||||||
|
namespace: Api::V1,
|
||||||
|
adapter: :attribute
|
||||||
|
).as_json
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
13
app/serializers/api/v1/inventory_item_serializer.rb
Normal file
13
app/serializers/api/v1/inventory_item_serializer.rb
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
module Api
|
||||||
|
module V1
|
||||||
|
class InventoryItemSerializer < ActiveModel::Serializer
|
||||||
|
type :inventory_items
|
||||||
|
attributes :id, :name
|
||||||
|
has_many :repository_cells, key: :inventory_cells,
|
||||||
|
serializer: InventoryCellSerializer,
|
||||||
|
class_name: 'RepositoryCell'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
10
app/serializers/api/v1/inventory_serializer.rb
Normal file
10
app/serializers/api/v1/inventory_serializer.rb
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
module Api
|
||||||
|
module V1
|
||||||
|
class InventorySerializer < ActiveModel::Serializer
|
||||||
|
type :inventories
|
||||||
|
attributes :id, :name
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
32
app/serializers/api/v1/repository_asset_value_serializer.rb
Normal file
32
app/serializers/api/v1/repository_asset_value_serializer.rb
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
module Api
|
||||||
|
module V1
|
||||||
|
class RepositoryAssetValueSerializer < ActiveModel::Serializer
|
||||||
|
attributes :file_id, :file_name, :file_size, :url
|
||||||
|
|
||||||
|
def file_id
|
||||||
|
object.asset&.id
|
||||||
|
end
|
||||||
|
|
||||||
|
def file_name
|
||||||
|
object.asset&.file_file_name
|
||||||
|
end
|
||||||
|
|
||||||
|
def file_size
|
||||||
|
object.asset&.file_file_size
|
||||||
|
end
|
||||||
|
|
||||||
|
def url
|
||||||
|
if !object.asset&.file_present
|
||||||
|
nil
|
||||||
|
elsif object.asset&.file&.is_stored_on_s3?
|
||||||
|
object.asset.presigned_url(download: true)
|
||||||
|
else
|
||||||
|
# separate api endpoint for local files download is needed
|
||||||
|
download_asset_path(object.asset.id)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
10
app/serializers/api/v1/repository_list_value_serializer.rb
Normal file
10
app/serializers/api/v1/repository_list_value_serializer.rb
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
module Api
|
||||||
|
module V1
|
||||||
|
class RepositoryListValueSerializer < ActiveModel::Serializer
|
||||||
|
attribute :formatted, key: :value
|
||||||
|
attribute :repository_list_item_id, key: :inventory_list_item_id
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,9 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
module Api
|
||||||
|
module V1
|
||||||
|
class RepositoryTextValueSerializer < ActiveModel::Serializer
|
||||||
|
attribute :formatted, key: :value
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -1,3 +1,5 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
module Api
|
module Api
|
||||||
module V1
|
module V1
|
||||||
class TeamSerializer < ActiveModel::Serializer
|
class TeamSerializer < ActiveModel::Serializer
|
||||||
|
|
|
@ -1,2 +1,4 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
ActiveModelSerializers.config.adapter = :json_api
|
ActiveModelSerializers.config.adapter = :json_api
|
||||||
ActiveModelSerializers.config.key_transform = :unaltered
|
ActiveModelSerializers.config.key_transform = :unaltered
|
||||||
|
|
|
@ -2,3 +2,4 @@
|
||||||
|
|
||||||
# Add new mime types for use in respond_to blocks:
|
# Add new mime types for use in respond_to blocks:
|
||||||
# Mime::Type.register "text/richtext", :rtf
|
# Mime::Type.register "text/richtext", :rtf
|
||||||
|
Mime::Type.register 'application/vnd.api+json', :json
|
||||||
|
|
|
@ -1943,6 +1943,12 @@ en:
|
||||||
status_ok: "Ok"
|
status_ok: "Ok"
|
||||||
expired_token: "Token is expired"
|
expired_token: "Token is expired"
|
||||||
invalid_token: "Token is invalid"
|
invalid_token: "Token is invalid"
|
||||||
|
v1:
|
||||||
|
inventory_data_types:
|
||||||
|
t0: "text"
|
||||||
|
t1: "date"
|
||||||
|
t2: "list"
|
||||||
|
t3: "file"
|
||||||
|
|
||||||
Add: "Add"
|
Add: "Add"
|
||||||
Asset: "File"
|
Asset: "File"
|
||||||
|
|
|
@ -542,6 +542,9 @@ Rails.application.routes.draw do
|
||||||
post 'auth/token', to: 'api#authenticate'
|
post 'auth/token', to: 'api#authenticate'
|
||||||
namespace :v1 do
|
namespace :v1 do
|
||||||
resources :teams, only: %i(index show) do
|
resources :teams, only: %i(index show) do
|
||||||
|
resources :inventories, only: %i(index show) do
|
||||||
|
get 'items', to: 'inventory_items#index'
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -0,0 +1,25 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
class ChangePrimaryKeyToBigintOnRepositories < ActiveRecord::Migration[5.1]
|
||||||
|
def up
|
||||||
|
change_column :repository_rows, :id, :bigint
|
||||||
|
change_column :repository_columns, :id, :bigint
|
||||||
|
change_column :repository_cells, :id, :bigint
|
||||||
|
change_column :repository_cells, :repository_row_id, :bigint
|
||||||
|
change_column :repository_cells, :value_id, :bigint
|
||||||
|
change_column :repository_text_values, :id, :bigint
|
||||||
|
change_column :repository_date_values, :id, :bigint
|
||||||
|
change_column :my_module_repository_rows, :repository_row_id, :bigint
|
||||||
|
end
|
||||||
|
|
||||||
|
def down
|
||||||
|
change_column :repository_rows, :id, :integer
|
||||||
|
change_column :repository_columns, :id, :integer
|
||||||
|
change_column :repository_cells, :id, :integer
|
||||||
|
change_column :repository_cells, :repository_row_id, :integer
|
||||||
|
change_column :repository_cells, :value_id, :integer
|
||||||
|
change_column :repository_text_values, :id, :integer
|
||||||
|
change_column :repository_date_values, :id, :integer
|
||||||
|
change_column :my_module_repository_rows, :repository_row_id, :integer
|
||||||
|
end
|
||||||
|
end
|
18
db/schema.rb
18
db/schema.rb
|
@ -10,7 +10,7 @@
|
||||||
#
|
#
|
||||||
# It's strongly recommended that you check this file into your version control system.
|
# It's strongly recommended that you check this file into your version control system.
|
||||||
|
|
||||||
ActiveRecord::Schema.define(version: 20180524091143) do
|
ActiveRecord::Schema.define(version: 20180806115201) do
|
||||||
|
|
||||||
# These are extensions that must be enabled in order to support this database
|
# These are extensions that must be enabled in order to support this database
|
||||||
enable_extension "plpgsql"
|
enable_extension "plpgsql"
|
||||||
|
@ -181,7 +181,7 @@ ActiveRecord::Schema.define(version: 20180524091143) do
|
||||||
end
|
end
|
||||||
|
|
||||||
create_table "my_module_repository_rows", id: :serial, force: :cascade do |t|
|
create_table "my_module_repository_rows", id: :serial, force: :cascade do |t|
|
||||||
t.integer "repository_row_id", null: false
|
t.bigint "repository_row_id", null: false
|
||||||
t.integer "my_module_id"
|
t.integer "my_module_id"
|
||||||
t.integer "assigned_by_id", null: false
|
t.integer "assigned_by_id", null: false
|
||||||
t.datetime "created_at"
|
t.datetime "created_at"
|
||||||
|
@ -379,11 +379,11 @@ ActiveRecord::Schema.define(version: 20180524091143) do
|
||||||
t.index ["last_modified_by_id"], name: "index_repository_asset_values_on_last_modified_by_id"
|
t.index ["last_modified_by_id"], name: "index_repository_asset_values_on_last_modified_by_id"
|
||||||
end
|
end
|
||||||
|
|
||||||
create_table "repository_cells", id: :serial, force: :cascade do |t|
|
create_table "repository_cells", force: :cascade do |t|
|
||||||
t.integer "repository_row_id"
|
t.bigint "repository_row_id"
|
||||||
t.integer "repository_column_id"
|
t.integer "repository_column_id"
|
||||||
t.string "value_type"
|
t.string "value_type"
|
||||||
t.integer "value_id"
|
t.bigint "value_id"
|
||||||
t.datetime "created_at"
|
t.datetime "created_at"
|
||||||
t.datetime "updated_at"
|
t.datetime "updated_at"
|
||||||
t.index ["repository_column_id"], name: "index_repository_cells_on_repository_column_id"
|
t.index ["repository_column_id"], name: "index_repository_cells_on_repository_column_id"
|
||||||
|
@ -391,7 +391,7 @@ ActiveRecord::Schema.define(version: 20180524091143) do
|
||||||
t.index ["value_type", "value_id"], name: "index_repository_cells_on_value_type_and_value_id"
|
t.index ["value_type", "value_id"], name: "index_repository_cells_on_value_type_and_value_id"
|
||||||
end
|
end
|
||||||
|
|
||||||
create_table "repository_columns", id: :serial, force: :cascade do |t|
|
create_table "repository_columns", force: :cascade do |t|
|
||||||
t.integer "repository_id"
|
t.integer "repository_id"
|
||||||
t.integer "created_by_id", null: false
|
t.integer "created_by_id", null: false
|
||||||
t.string "name"
|
t.string "name"
|
||||||
|
@ -401,7 +401,7 @@ ActiveRecord::Schema.define(version: 20180524091143) do
|
||||||
t.index ["repository_id"], name: "index_repository_columns_on_repository_id"
|
t.index ["repository_id"], name: "index_repository_columns_on_repository_id"
|
||||||
end
|
end
|
||||||
|
|
||||||
create_table "repository_date_values", id: :serial, force: :cascade do |t|
|
create_table "repository_date_values", force: :cascade do |t|
|
||||||
t.datetime "data"
|
t.datetime "data"
|
||||||
t.datetime "created_at"
|
t.datetime "created_at"
|
||||||
t.datetime "updated_at"
|
t.datetime "updated_at"
|
||||||
|
@ -435,7 +435,7 @@ ActiveRecord::Schema.define(version: 20180524091143) do
|
||||||
t.index ["repository_list_item_id"], name: "index_repository_list_values_on_repository_list_item_id"
|
t.index ["repository_list_item_id"], name: "index_repository_list_values_on_repository_list_item_id"
|
||||||
end
|
end
|
||||||
|
|
||||||
create_table "repository_rows", id: :serial, force: :cascade do |t|
|
create_table "repository_rows", force: :cascade do |t|
|
||||||
t.integer "repository_id"
|
t.integer "repository_id"
|
||||||
t.integer "created_by_id", null: false
|
t.integer "created_by_id", null: false
|
||||||
t.integer "last_modified_by_id", null: false
|
t.integer "last_modified_by_id", null: false
|
||||||
|
@ -456,7 +456,7 @@ ActiveRecord::Schema.define(version: 20180524091143) do
|
||||||
t.index ["user_id"], name: "index_repository_table_states_on_user_id"
|
t.index ["user_id"], name: "index_repository_table_states_on_user_id"
|
||||||
end
|
end
|
||||||
|
|
||||||
create_table "repository_text_values", id: :serial, force: :cascade do |t|
|
create_table "repository_text_values", force: :cascade do |t|
|
||||||
t.string "data"
|
t.string "data"
|
||||||
t.datetime "created_at"
|
t.datetime "created_at"
|
||||||
t.datetime "updated_at"
|
t.datetime "updated_at"
|
||||||
|
|
|
@ -2,7 +2,7 @@ version: '2'
|
||||||
services:
|
services:
|
||||||
db:
|
db:
|
||||||
container_name: scinote_db_production
|
container_name: scinote_db_production
|
||||||
image: postgres:9.4
|
image: postgres:9.6
|
||||||
volumes:
|
volumes:
|
||||||
- scinote_production_postgres:/var/lib/postgresql/data
|
- scinote_production_postgres:/var/lib/postgresql/data
|
||||||
|
|
||||||
|
|
|
@ -2,7 +2,7 @@ version: '2'
|
||||||
services:
|
services:
|
||||||
db:
|
db:
|
||||||
container_name: scinote_db_development
|
container_name: scinote_db_development
|
||||||
image: postgres:9.4
|
image: postgres:9.6
|
||||||
volumes:
|
volumes:
|
||||||
- scinote_development_postgres:/var/lib/postgresql/data
|
- scinote_development_postgres:/var/lib/postgresql/data
|
||||||
|
|
||||||
|
|
95
spec/requests/api/v1/inventories_controller_spec.rb
Normal file
95
spec/requests/api/v1/inventories_controller_spec.rb
Normal file
|
@ -0,0 +1,95 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
require 'rails_helper'
|
||||||
|
|
||||||
|
RSpec.describe "Api::V1::InventoriesController", type: :request do
|
||||||
|
before :all do
|
||||||
|
@user = create(:user)
|
||||||
|
@teams = create_list(:team, 2, created_by: @user)
|
||||||
|
create(:user_team, user: @user, team: @teams.first, role: 2)
|
||||||
|
|
||||||
|
# valid_inventories
|
||||||
|
create(:repository, name: Faker::Name.unique.name,
|
||||||
|
created_by: @user, team: @teams.first)
|
||||||
|
create(:repository, name: Faker::Name.unique.name,
|
||||||
|
created_by: @user, team: @teams.first)
|
||||||
|
|
||||||
|
# unaccessable_inventories
|
||||||
|
create(:repository, name: Faker::Name.unique.name,
|
||||||
|
created_by: @user, team: @teams.second)
|
||||||
|
create(:repository, name: Faker::Name.unique.name,
|
||||||
|
created_by: @user, team: @teams.second)
|
||||||
|
|
||||||
|
@valid_headers =
|
||||||
|
{ 'Authorization': 'Bearer ' + generate_token(@user.id) }
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'GET inventories, #index' do
|
||||||
|
it 'Response with correct inventories' do
|
||||||
|
hash_body = nil
|
||||||
|
get api_v1_team_inventories_path(team_id: @teams.first.id),
|
||||||
|
headers: @valid_headers
|
||||||
|
expect { hash_body = json }.not_to raise_exception
|
||||||
|
expect(hash_body[:data]).to match(
|
||||||
|
ActiveModelSerializers::SerializableResource
|
||||||
|
.new(@teams.first.repositories,
|
||||||
|
each_serializer: Api::V1::InventorySerializer)
|
||||||
|
.as_json[:data]
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'When invalid request, user in not member of the team' do
|
||||||
|
hash_body = nil
|
||||||
|
get api_v1_team_inventories_path(team_id: @teams.second.id),
|
||||||
|
headers: @valid_headers
|
||||||
|
expect(response).to have_http_status(403)
|
||||||
|
expect { hash_body = json }.not_to raise_exception
|
||||||
|
expect(hash_body).to match({})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'GET inventory, #show' do
|
||||||
|
it 'When valid request, user is member of the team' do
|
||||||
|
hash_body = nil
|
||||||
|
get api_v1_team_inventory_path(team_id: @teams.first.id,
|
||||||
|
id: @teams.first.repositories.first.id),
|
||||||
|
headers: @valid_headers
|
||||||
|
expect { hash_body = json }.not_to raise_exception
|
||||||
|
expect(hash_body[:data]).to match(
|
||||||
|
ActiveModelSerializers::SerializableResource
|
||||||
|
.new(@teams.first.repositories.first,
|
||||||
|
serializer: Api::V1::InventorySerializer)
|
||||||
|
.as_json[:data]
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'When invalid request, user in not member of the team' do
|
||||||
|
hash_body = nil
|
||||||
|
get api_v1_team_inventory_path(team_id: @teams.second.id,
|
||||||
|
id: @teams.second.repositories.first.id),
|
||||||
|
headers: @valid_headers
|
||||||
|
expect(response).to have_http_status(403)
|
||||||
|
expect { hash_body = json }.not_to raise_exception
|
||||||
|
expect(hash_body).to match({})
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'When invalid request, non existing inventory' do
|
||||||
|
hash_body = nil
|
||||||
|
get api_v1_team_inventory_path(team_id: @teams.first.id, id: 123),
|
||||||
|
headers: @valid_headers
|
||||||
|
expect(response).to have_http_status(404)
|
||||||
|
expect { hash_body = json }.not_to raise_exception
|
||||||
|
expect(hash_body).to match({})
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'When invalid request, repository from another team' do
|
||||||
|
hash_body = nil
|
||||||
|
get api_v1_team_inventory_path(team_id: @teams.first.id,
|
||||||
|
id: @teams.second.repositories.first.id),
|
||||||
|
headers: @valid_headers
|
||||||
|
expect(response).to have_http_status(404)
|
||||||
|
expect { hash_body = json }.not_to raise_exception
|
||||||
|
expect(hash_body).to match({})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
129
spec/requests/api/v1/inventory_items_controller_spec.rb
Normal file
129
spec/requests/api/v1/inventory_items_controller_spec.rb
Normal file
|
@ -0,0 +1,129 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
require 'rails_helper'
|
||||||
|
|
||||||
|
RSpec.describe 'Api::V1::InventoryItemsController', type: :request do
|
||||||
|
before :all do
|
||||||
|
@user = create(:user)
|
||||||
|
@teams = create_list(:team, 2, created_by: @user)
|
||||||
|
create(:user_team, user: @user, team: @teams.first, role: 2)
|
||||||
|
|
||||||
|
# valid_inventory
|
||||||
|
@valid_inventory = create(:repository, name: Faker::Name.unique.name,
|
||||||
|
created_by: @user, team: @teams.first)
|
||||||
|
|
||||||
|
# unaccessable_inventory
|
||||||
|
create(:repository, name: Faker::Name.unique.name,
|
||||||
|
created_by: @user, team: @teams.second)
|
||||||
|
|
||||||
|
text_column = create(:repository_column, name: Faker::Name.unique.name,
|
||||||
|
repository: @valid_inventory, data_type: :RepositoryTextValue)
|
||||||
|
list_column = create(:repository_column, name: Faker::Name.unique.name,
|
||||||
|
repository: @valid_inventory, data_type: :RepositoryListValue)
|
||||||
|
list_item =
|
||||||
|
create(:repository_list_item, repository: @valid_inventory,
|
||||||
|
repository_column: list_column, data: Faker::Name.unique.name)
|
||||||
|
file_column = create(:repository_column, name: Faker::Name.unique.name,
|
||||||
|
repository: @valid_inventory, data_type: :RepositoryAssetValue)
|
||||||
|
asset = create(:asset)
|
||||||
|
|
||||||
|
create_list(:repository_row, 100, repository: @valid_inventory)
|
||||||
|
|
||||||
|
@valid_inventory.repository_rows.each do |row|
|
||||||
|
create(:repository_text_value,
|
||||||
|
data: Faker::Name.name,
|
||||||
|
repository_cell_attributes:
|
||||||
|
{ repository_row: row, repository_column: text_column })
|
||||||
|
create(:repository_list_value, repository_list_item: list_item,
|
||||||
|
repository_cell_attributes:
|
||||||
|
{ repository_row: row, repository_column: list_column })
|
||||||
|
create(:repository_asset_value, asset: asset,
|
||||||
|
repository_cell_attributes:
|
||||||
|
{ repository_row: row, repository_column: file_column })
|
||||||
|
end
|
||||||
|
|
||||||
|
@valid_headers =
|
||||||
|
{ 'Authorization': 'Bearer ' + generate_token(@user.id) }
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'GET inventory_items, #index' do
|
||||||
|
it 'Response with correct inventory items, default per page' do
|
||||||
|
hash_body = nil
|
||||||
|
get api_v1_team_inventory_items_path(
|
||||||
|
team_id: @teams.first.id,
|
||||||
|
inventory_id: @teams.first.repositories.first.id
|
||||||
|
), headers: @valid_headers
|
||||||
|
expect { hash_body = json }.not_to raise_exception
|
||||||
|
expect(hash_body[:data]).to match(
|
||||||
|
ActiveModelSerializers::SerializableResource
|
||||||
|
.new(@valid_inventory.repository_rows.limit(10),
|
||||||
|
each_serializer: Api::V1::InventoryItemSerializer,
|
||||||
|
include: :inventory_cells)
|
||||||
|
.as_json[:data]
|
||||||
|
)
|
||||||
|
expect(hash_body[:included]).to match(
|
||||||
|
ActiveModelSerializers::SerializableResource
|
||||||
|
.new(@valid_inventory.repository_rows.limit(10),
|
||||||
|
each_serializer: Api::V1::InventoryItemSerializer,
|
||||||
|
include: :inventory_cells)
|
||||||
|
.as_json[:included]
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'Response with correct inventory items, 100 per page' do
|
||||||
|
hash_body = nil
|
||||||
|
get api_v1_team_inventory_items_path(
|
||||||
|
team_id: @teams.first.id,
|
||||||
|
inventory_id: @teams.first.repositories.first.id
|
||||||
|
), params: { page_size: 100 }, headers: @valid_headers
|
||||||
|
expect { hash_body = json }.not_to raise_exception
|
||||||
|
expect(hash_body[:data]).to match(
|
||||||
|
ActiveModelSerializers::SerializableResource
|
||||||
|
.new(@valid_inventory.repository_rows.limit(100),
|
||||||
|
each_serializer: Api::V1::InventoryItemSerializer,
|
||||||
|
include: :inventory_cells)
|
||||||
|
.as_json[:data]
|
||||||
|
)
|
||||||
|
expect(hash_body[:included]).to match(
|
||||||
|
ActiveModelSerializers::SerializableResource
|
||||||
|
.new(@valid_inventory.repository_rows.limit(100),
|
||||||
|
each_serializer: Api::V1::InventoryItemSerializer,
|
||||||
|
include: :inventory_cells)
|
||||||
|
.as_json[:included]
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'When invalid request, user in not member of the team' do
|
||||||
|
hash_body = nil
|
||||||
|
get api_v1_team_inventory_items_path(
|
||||||
|
team_id: @teams.second.id,
|
||||||
|
inventory_id: @teams.second.repositories.first.id
|
||||||
|
), headers: @valid_headers
|
||||||
|
expect(response).to have_http_status(403)
|
||||||
|
expect { hash_body = json }.not_to raise_exception
|
||||||
|
expect(hash_body).to match({})
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'When invalid request, non existing inventory' do
|
||||||
|
hash_body = nil
|
||||||
|
get api_v1_team_inventory_items_path(
|
||||||
|
team_id: @teams.first.id,
|
||||||
|
inventory_id: 123
|
||||||
|
), headers: @valid_headers
|
||||||
|
expect(response).to have_http_status(404)
|
||||||
|
expect { hash_body = json }.not_to raise_exception
|
||||||
|
expect(hash_body).to match({})
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'When invalid request, repository from another team' do
|
||||||
|
hash_body = nil
|
||||||
|
get api_v1_team_inventory_items_path(
|
||||||
|
team_id: @teams.first.id,
|
||||||
|
inventory_id: @teams.second.repositories.first.id
|
||||||
|
), headers: @valid_headers
|
||||||
|
expect(response).to have_http_status(404)
|
||||||
|
expect { hash_body = json }.not_to raise_exception
|
||||||
|
expect(hash_body).to match({})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Loading…
Add table
Reference in a new issue