@ -763,6 +763,7 @@ RSpec.describe FormController, type: :request do
}
}
end
end
context " when the log will not be a duplicate " do
before do
before do
post " /lettings-logs/ #{ lettings_log . id } / #{ page_id . dasherize } " , params :
post " /lettings-logs/ #{ lettings_log . id } / #{ page_id . dasherize } " , params :
end
end
@ -783,21 +784,143 @@ RSpec.describe FormController, type: :request do
expect ( whodunnit_actor ) . to be_a ( User )
expect ( whodunnit_actor ) . to be_a ( User )
expect ( whodunnit_actor . id ) . to eq ( user . id )
expect ( whodunnit_actor . id ) . to eq ( user . id )
end
end
end
context " and duplicate logs " do
context " when the answer makes the log a duplicate " do
let ( :duplicate_logs ) { create_list ( :lettings_log , 2 ) }
context " with one other log " do
let ( :new_duplicate ) { create ( :lettings_log ) }
before do
before do
allow ( LettingsLog ) . to receive ( :duplicate_logs ) . and_return ( duplicate_logs )
allow ( LettingsLog ) . to receive ( :duplicate_logs ) . and_return ( LettingsLog . where ( id : new_duplicate . id ) )
post " /lettings-logs/ #{ lettings_log . id } / #{ page_id . dasherize } " , params :
post " /lettings-logs/ #{ lettings_log . id } / #{ page_id . dasherize } " , params :
end
end
it " sets a new duplicate set id on both logs " do
lettings_log . reload
new_duplicate . reload
expect ( lettings_log . duplicate_set_id ) . not_to be_nil
expect ( lettings_log . duplicate_set_id ) . to eql ( new_duplicate . duplicate_set_id )
end
it " redirects to the duplicate logs page " do
it " redirects to the duplicate logs page " do
expect ( response ) . to redirect_to ( " /lettings-logs/ #{ lettings_log . id } /duplicate-logs?original_log_id= #{ lettings_log . id } " )
expect ( response ) . to redirect_to ( " /lettings-logs/ #{ lettings_log . id } /duplicate-logs?original_log_id= #{ lettings_log . id } " )
follow_redirect!
follow_redirect!
expect ( page ) . to have_content ( " These logs are duplicates " )
expect ( page ) . to have_content ( " These logs are duplicates " )
end
end
end
end
context " with a set of other logs " do
let ( :duplicate_set_id ) { 100 }
let ( :new_duplicates ) { create_list ( :lettings_log , 2 , duplicate_set_id : ) }
before do
allow ( LettingsLog ) . to receive ( :duplicate_logs ) . and_return ( LettingsLog . where ( id : new_duplicates . pluck ( :id ) ) )
post " /lettings-logs/ #{ lettings_log . id } / #{ page_id . dasherize } " , params :
end
it " sets the logs duplicate set id to that of the set it is now part of " do
lettings_log . reload
expect ( lettings_log . duplicate_set_id ) . to eql ( duplicate_set_id )
new_duplicates . each do | log |
log . reload
expect ( log . duplicate_set_id ) . to eql ( duplicate_set_id )
end
end
it " redirects to the duplicate logs page " do
expect ( response ) . to redirect_to ( " /lettings-logs/ #{ lettings_log . id } /duplicate-logs?original_log_id= #{ lettings_log . id } " )
follow_redirect!
expect ( page ) . to have_content ( " These logs are duplicates " )
end
end
context " when the log was previously in a different duplicate set " do
context " with a single other log " do
let ( :old_duplicate_set_id ) { 110 }
let! ( :old_duplicate ) { create ( :lettings_log , duplicate_set_id : old_duplicate_set_id ) }
let ( :lettings_log ) { create ( :lettings_log , assigned_to : user , duplicate_set_id : old_duplicate_set_id ) }
let ( :new_duplicate ) { create ( :lettings_log ) }
before do
allow ( LettingsLog ) . to receive ( :duplicate_logs ) . and_return ( LettingsLog . where ( id : new_duplicate . id ) )
post " /lettings-logs/ #{ lettings_log . id } / #{ page_id . dasherize } " , params :
end
it " updates the relevant duplicate set ids " do
lettings_log . reload
old_duplicate . reload
new_duplicate . reload
expect ( old_duplicate . duplicate_set_id ) . to be_nil
expect ( lettings_log . duplicate_set_id ) . not_to be_nil
expect ( lettings_log . duplicate_set_id ) . to eql ( new_duplicate . duplicate_set_id )
end
end
context " with multiple other logs " do
let ( :old_duplicate_set_id ) { 120 }
let! ( :old_duplicates ) { create_list ( :lettings_log , 2 , duplicate_set_id : old_duplicate_set_id ) }
let ( :lettings_log ) { create ( :lettings_log , assigned_to : user , duplicate_set_id : old_duplicate_set_id ) }
let ( :new_duplicate ) { create ( :lettings_log ) }
before do
allow ( LettingsLog ) . to receive ( :duplicate_logs ) . and_return ( LettingsLog . where ( id : new_duplicate . id ) )
post " /lettings-logs/ #{ lettings_log . id } / #{ page_id . dasherize } " , params :
end
it " updates the relevant duplicate set ids " do
lettings_log . reload
new_duplicate . reload
old_duplicates . each do | log |
log . reload
expect ( log . duplicate_set_id ) . to eql ( old_duplicate_set_id )
end
expect ( lettings_log . duplicate_set_id ) . not_to be_nil
expect ( lettings_log . duplicate_set_id ) . not_to eql ( old_duplicate_set_id )
expect ( lettings_log . duplicate_set_id ) . to eql ( new_duplicate . duplicate_set_id )
end
end
end
end
context " when the answer makes the log stop being a duplicate " do
context " when the log had one duplicate " do
let ( :old_duplicate_set_id ) { 130 }
let! ( :old_duplicate ) { create ( :lettings_log , duplicate_set_id : old_duplicate_set_id ) }
let ( :lettings_log ) { create ( :lettings_log , assigned_to : user , duplicate_set_id : old_duplicate_set_id ) }
before do
allow ( LettingsLog ) . to receive ( :duplicate_logs ) . and_return ( LettingsLog . none )
post " /lettings-logs/ #{ lettings_log . id } / #{ page_id . dasherize } " , params :
end
it " updates the relevant duplicate set ids " do
lettings_log . reload
old_duplicate . reload
expect ( old_duplicate . duplicate_set_id ) . to be_nil
expect ( lettings_log . duplicate_set_id ) . to be_nil
end
end
context " when the log had multiple duplicates " do
let ( :old_duplicate_set_id ) { 140 }
let! ( :old_duplicates ) { create_list ( :lettings_log , 2 , duplicate_set_id : old_duplicate_set_id ) }
let ( :lettings_log ) { create ( :lettings_log , assigned_to : user , duplicate_set_id : old_duplicate_set_id ) }
before do
allow ( LettingsLog ) . to receive ( :duplicate_logs ) . and_return ( LettingsLog . none )
post " /lettings-logs/ #{ lettings_log . id } / #{ page_id . dasherize } " , params :
end
it " updates the relevant duplicate set ids " do
lettings_log . reload
old_duplicates . each do | log |
log . reload
expect ( log . duplicate_set_id ) . to eql ( old_duplicate_set_id )
end
expect ( lettings_log . duplicate_set_id ) . to be_nil
end
end
end
end
end
context " with valid sales answers " do
context " with valid sales answers " do
@ -816,13 +939,22 @@ RSpec.describe FormController, type: :request do
} ,
} ,
}
}
end
end
let ( :page_id ) { " buyer_1_age " }
context " and duplicate logs " do
context " when the answer makes the log a duplicate " do
let! ( :duplicate_logs ) { create_list ( :sales_log , 2 ) }
context " with one other log " do
let ( :new_duplicate ) { create ( :sales_log ) }
before do
before do
allow ( SalesLog ) . to receive ( :duplicate_logs ) . and_return ( duplicate_logs )
allow ( SalesLog ) . to receive ( :duplicate_logs ) . and_return ( SalesLog . where ( id : new_duplicate . id ) )
post " /sales-logs/ #{ sales_log . id } /buyer-1-age " , params :
post " /sales-logs/ #{ sales_log . id } / #{ page_id . dasherize } " , params :
end
it " sets a new duplicate set id on both logs " do
sales_log . reload
new_duplicate . reload
expect ( sales_log . duplicate_set_id ) . not_to be_nil
expect ( sales_log . duplicate_set_id ) . to eql ( new_duplicate . duplicate_set_id )
end
end
it " redirects to the duplicate logs page " do
it " redirects to the duplicate logs page " do
@ -831,6 +963,119 @@ RSpec.describe FormController, type: :request do
expect ( page ) . to have_content ( " These logs are duplicates " )
expect ( page ) . to have_content ( " These logs are duplicates " )
end
end
end
end
context " with a set of other logs " do
let ( :duplicate_set_id ) { 100 }
let ( :new_duplicates ) { create_list ( :sales_log , 2 , duplicate_set_id : ) }
before do
allow ( SalesLog ) . to receive ( :duplicate_logs ) . and_return ( SalesLog . where ( id : new_duplicates . pluck ( :id ) ) )
post " /sales-logs/ #{ sales_log . id } / #{ page_id . dasherize } " , params :
end
it " sets the logs duplicate set id to that of the set it is now part of " do
sales_log . reload
expect ( sales_log . duplicate_set_id ) . to eql ( duplicate_set_id )
new_duplicates . each do | log |
log . reload
expect ( log . duplicate_set_id ) . to eql ( duplicate_set_id )
end
end
it " redirects to the duplicate logs page " do
expect ( response ) . to redirect_to ( " /sales-logs/ #{ sales_log . id } /duplicate-logs?original_log_id= #{ sales_log . id } " )
follow_redirect!
expect ( page ) . to have_content ( " These logs are duplicates " )
end
end
context " when the log was previously in a different duplicate set " do
context " with a single other log " do
let ( :old_duplicate_set_id ) { 110 }
let! ( :old_duplicate ) { create ( :sales_log , duplicate_set_id : old_duplicate_set_id ) }
let ( :sales_log ) { create ( :sales_log , assigned_to : user , duplicate_set_id : old_duplicate_set_id ) }
let ( :new_duplicate ) { create ( :sales_log ) }
before do
allow ( SalesLog ) . to receive ( :duplicate_logs ) . and_return ( SalesLog . where ( id : new_duplicate . id ) )
post " /sales-logs/ #{ sales_log . id } / #{ page_id . dasherize } " , params :
end
it " updates the relevant duplicate set ids " do
sales_log . reload
old_duplicate . reload
new_duplicate . reload
expect ( old_duplicate . duplicate_set_id ) . to be_nil
expect ( sales_log . duplicate_set_id ) . not_to be_nil
expect ( sales_log . duplicate_set_id ) . to eql ( new_duplicate . duplicate_set_id )
end
end
context " with multiple other logs " do
let ( :old_duplicate_set_id ) { 120 }
let! ( :old_duplicates ) { create_list ( :sales_log , 2 , duplicate_set_id : old_duplicate_set_id ) }
let ( :sales_log ) { create ( :sales_log , assigned_to : user , duplicate_set_id : old_duplicate_set_id ) }
let ( :new_duplicate ) { create ( :sales_log ) }
before do
allow ( SalesLog ) . to receive ( :duplicate_logs ) . and_return ( SalesLog . where ( id : new_duplicate . id ) )
post " /sales-logs/ #{ sales_log . id } / #{ page_id . dasherize } " , params :
end
it " updates the relevant duplicate set ids " do
sales_log . reload
new_duplicate . reload
old_duplicates . each do | log |
log . reload
expect ( log . duplicate_set_id ) . to eql ( old_duplicate_set_id )
end
expect ( sales_log . duplicate_set_id ) . not_to be_nil
expect ( sales_log . duplicate_set_id ) . not_to eql ( old_duplicate_set_id )
expect ( sales_log . duplicate_set_id ) . to eql ( new_duplicate . duplicate_set_id )
end
end
end
end
context " when the answer makes the log stop being a duplicate " do
context " when the log had one duplicate " do
let ( :old_duplicate_set_id ) { 130 }
let! ( :old_duplicate ) { create ( :sales_log , duplicate_set_id : old_duplicate_set_id ) }
let ( :sales_log ) { create ( :sales_log , assigned_to : user , duplicate_set_id : old_duplicate_set_id ) }
before do
allow ( SalesLog ) . to receive ( :duplicate_logs ) . and_return ( SalesLog . none )
post " /sales-logs/ #{ sales_log . id } / #{ page_id . dasherize } " , params :
end
it " updates the relevant duplicate set ids " do
sales_log . reload
old_duplicate . reload
expect ( old_duplicate . duplicate_set_id ) . to be_nil
expect ( sales_log . duplicate_set_id ) . to be_nil
end
end
context " when the log had multiple duplicates " do
let ( :old_duplicate_set_id ) { 140 }
let! ( :old_duplicates ) { create_list ( :sales_log , 2 , duplicate_set_id : old_duplicate_set_id ) }
let ( :sales_log ) { create ( :sales_log , assigned_to : user , duplicate_set_id : old_duplicate_set_id ) }
before do
allow ( SalesLog ) . to receive ( :duplicate_logs ) . and_return ( SalesLog . none )
post " /sales-logs/ #{ sales_log . id } / #{ page_id . dasherize } " , params :
end
it " updates the relevant duplicate set ids " do
sales_log . reload
old_duplicates . each do | log |
log . reload
expect ( log . duplicate_set_id ) . to eql ( old_duplicate_set_id )
end
expect ( sales_log . duplicate_set_id ) . to be_nil
end
end
end
end
end
context " when the question has a conditional question " do
context " when the question has a conditional question " do