Check phase dates and that draft version is not final before creating annotations

This commit is contained in:
Amaia Castro
2017-01-13 17:57:03 +01:00
parent a56898fed7
commit 49e66a431c
5 changed files with 90 additions and 9 deletions

View File

@@ -20,15 +20,22 @@ class Legislation::AnnotationsController < ApplicationController
end end
def create def create
@annotation = Legislation::Annotation.new(annotation_params) if !@process.open_phase?(:allegations) || @draft_version.final_version?
render json: {}, status: :not_found and return
end
@annotation = @draft_version.annotations.new(annotation_params)
@annotation.author = current_user @annotation.author = current_user
if @annotation.save if @annotation.save
track_event
render json: @annotation.to_json render json: @annotation.to_json
else
render json: {}, status: :unprocessable_entity
end end
end end
def search def search
@annotations = Legislation::Annotation.where(legislation_draft_version_id: params[:legislation_draft_version_id]) @annotations = @draft_version.annotations
annotations_hash = { total: @annotations.size, rows: @annotations } annotations_hash = { total: @annotations.size, rows: @annotations }
render json: annotations_hash.to_json render json: annotations_hash.to_json
end end
@@ -43,7 +50,12 @@ class Legislation::AnnotationsController < ApplicationController
params params
.require(:annotation) .require(:annotation)
.permit(:quote, :text, ranges: [:start, :startOffset, :end, :endOffset]) .permit(:quote, :text, ranges: [:start, :startOffset, :end, :endOffset])
.merge(legislation_draft_version_id: params[:legislation_draft_version_id]) end
def track_event
ahoy.track "legislation_annotation_created".to_sym,
"legislation_annotation_id": @annotation.id,
"legislation_draft_version_id": @draft_version.id
end end
end end

View File

@@ -19,7 +19,7 @@ class Legislation::AnswersController < Legislation::BaseController
end end
else else
respond_to do |format| respond_to do |format|
format.js format.js { render json: {} , status: :not_found }
format.html { redirect_to legislation_process_question_path(@process, @question), alert: t('legislation.questions.participation.phase_not_open') } format.html { redirect_to legislation_process_question_path(@process, @question), alert: t('legislation.questions.participation.phase_not_open') }
end end
end end

View File

@@ -0,0 +1,70 @@
require 'rails_helper'
describe Legislation::AnnotationsController do
describe 'POST create' do
before(:each) do
@process = create(:legislation_process, allegations_start_date: Date.current - 3.day, allegations_end_date: Date.current + 2.days)
@draft_version = create(:legislation_draft_version, :published, process: @process, title: "Version 1")
@final_version = create(:legislation_draft_version, :published, :final_version, process: @process, title: "Final version")
@user = create(:user, :level_two)
end
it 'should create an ahoy event' do
sign_in @user
post :create, process_id: @process.id,
draft_version_id: @draft_version.id,
annotation: {
"quote"=>"Ordenación Territorial",
"ranges"=>[{"start"=>"/p[1]", "startOffset"=>1, "end"=>"/p[1]", "endOffset"=>3}],
"text": "una anotacion"
}
expect(Ahoy::Event.where(name: :legislation_annotation_created).count).to eq 1
expect(Ahoy::Event.last.properties['legislation_annotation_id']).to eq Legislation::Annotation.last.id
end
it 'should not create an annotation if the draft version is a final version' do
sign_in @user
post :create, process_id: @process.id,
draft_version_id: @final_version.id,
annotation: {
"quote"=>"Ordenación Territorial",
"ranges"=>[{"start"=>"/p[1]", "startOffset"=>1, "end"=>"/p[1]", "endOffset"=>3}],
"text": "una anotacion"
}
expect(response).to have_http_status(:not_found)
end
it 'should create an annotation if the process allegations phase is open' do
sign_in @user
expect do
xhr :post, :create, process_id: @process.id,
draft_version_id: @draft_version.id,
annotation: {
"quote"=>"Ordenación Territorial",
"ranges"=>[{"start"=>"/p[1]", "startOffset"=>1, "end"=>"/p[1]", "endOffset"=>3}],
"text": "una anotacion"
}
end.to change { @draft_version.annotations.count }.by(1)
end
it 'should not create an annotation if the process allegations phase is not open' do
sign_in @user
@process.update_attribute(:allegations_end_date, Date.current - 1.day)
expect do
xhr :post, :create, process_id: @process.id,
draft_version_id: @draft_version.id,
annotation: {
"quote"=>"Ordenación Territorial",
"ranges"=>[{"start"=>"/p[1]", "startOffset"=>1, "end"=>"/p[1]", "endOffset"=>3}],
"text": "una anotacion"
}
end.to_not change { @draft_version.annotations.count }
end
end
end

View File

@@ -4,17 +4,12 @@ describe Legislation::AnswersController do
describe 'POST create' do describe 'POST create' do
before(:each) do before(:each) do
InvisibleCaptcha.timestamp_enabled = false
@process = create(:legislation_process, debate_start_date: Date.current - 3.day, debate_end_date: Date.current + 2.days) @process = create(:legislation_process, debate_start_date: Date.current - 3.day, debate_end_date: Date.current + 2.days)
@question = create(:legislation_question, process: @process, title: "Question 1") @question = create(:legislation_question, process: @process, title: "Question 1")
@question_option = create(:legislation_question_option, question: @question, value: "Yes") @question_option = create(:legislation_question_option, question: @question, value: "Yes")
@user = create(:user, :level_two) @user = create(:user, :level_two)
end end
after(:each) do
InvisibleCaptcha.timestamp_enabled = true
end
it 'should create an ahoy event' do it 'should create an ahoy event' do
sign_in @user sign_in @user

View File

@@ -499,6 +499,10 @@ FactoryGirl.define do
trait :published do trait :published do
status "published" status "published"
end end
trait :final_version do
final_version true
end
end end
factory :legislation_annotation, class: 'Legislation::Annotation' do factory :legislation_annotation, class: 'Legislation::Annotation' do