122 lines
4.8 KiB
Ruby
122 lines
4.8 KiB
Ruby
require 'spec_helper'
|
|
|
|
describe PerformanceSample do
|
|
|
|
let(:user1) { FactoryGirl.create(:user) }
|
|
let(:user2) { FactoryGirl.create(:user) }
|
|
let(:claimed_recording) { FactoryGirl.create(:claimed_recording) }
|
|
|
|
describe "index" do
|
|
|
|
before(:all) do
|
|
PerformanceSample.delete_all
|
|
|
|
@user1_sample1 = PerformanceSample.new(:user_id => user1.id, :service_type => "jamkazam", :claimed_recording_id => claimed_recording.id)
|
|
@user1_sample1.save!
|
|
|
|
@user1_sample2 = PerformanceSample.new(:user_id => user1.id, :service_type => "youtube", :service_id => "12345")
|
|
@user1_sample2.save!
|
|
|
|
@user2_sample1 = PerformanceSample.new(:user_id => user2.id, :service_type => "soundcloud", :service_id => "67890")
|
|
@user2_sample1.save!
|
|
end
|
|
|
|
context "when request is valid" do
|
|
it "should return all records for user" do
|
|
sample = PerformanceSample.index({:id => user1.id})
|
|
sample.count.should == 2
|
|
|
|
sample = PerformanceSample.index({:id => user2.id})
|
|
sample.count.should == 1
|
|
end
|
|
end
|
|
|
|
context "when request is invalid" do
|
|
it "should raise error when options are missing" do
|
|
lambda{PerformanceSample.index}.should raise_error(JamArgumentError)
|
|
end
|
|
|
|
it "should raise error when user id is missing" do
|
|
lambda{PerformanceSample.index({:id => ""})}.should raise_error(JamArgumentError)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe "create" do
|
|
|
|
before(:all) do
|
|
PerformanceSample.delete_all
|
|
end
|
|
|
|
context "when request is valid" do
|
|
it "should save successfully" do
|
|
PerformanceSample.create(user1, {:user_id => user1.id, :service_type => "youtube", :service_id => "12345"})
|
|
|
|
# make sure we can save a second PerformanceSample for same user and type
|
|
PerformanceSample.create(user1, {:user_id => user1.id, :service_type => "youtube", :service_id => "67890"})
|
|
end
|
|
end
|
|
|
|
context "when request is not valid" do
|
|
it "should raise PermissionError if requester id does not match id in request" do
|
|
lambda{PerformanceSample.create(user1, {:user_id => user2.id, :service_type => "soundcloud", :service_id => "12345"})}.should raise_error(PermissionError)
|
|
end
|
|
|
|
it "should raise error if service type is missing" do
|
|
lambda{PerformanceSample.create(user1, {:user_id => user1.id, :service_id => "12345"})}.should raise_error(StateError)
|
|
end
|
|
|
|
it "should raise error if service id is missing for non-JamKazam sample" do
|
|
lambda{PerformanceSample.create(user1, {:user_id => user1.id, :service_type => "youtube"})}.should raise_error(StateError)
|
|
end
|
|
|
|
it "should raise error if recording id is missing for JamKazam sample" do
|
|
lambda{PerformanceSample.create(user1, {:user_id => user1.id, :service_type => "jamkazam"})}.should raise_error(StateError)
|
|
end
|
|
|
|
it "should not allow duplicate type/service id combination for non-JamKazam sample" do
|
|
PerformanceSample.create(user1, {:user_id => user1.id, :service_type => "youtube", :service_id => "12345"})
|
|
lambda{PerformanceSample.create(user1, {:user_id => user1.id, :service_type => "youtube", :service_id => "12345"})}.should raise_error(ConflictError)
|
|
end
|
|
|
|
it "should not allow duplicate type/recording id combination for JamKazam sample" do
|
|
PerformanceSample.create(user1, {:user_id => user1.id, :service_type => "jamkazam", :claimed_recording_id => claimed_recording.id})
|
|
lambda{PerformanceSample.create(user1, {:user_id => user1.id, :service_type => "jamkazam", :claimed_recording_id => claimed_recording.id})}.should raise_error(ConflictError)
|
|
end
|
|
end
|
|
end
|
|
|
|
|
|
describe "destroy" do
|
|
|
|
before(:all) do
|
|
PerformanceSample.delete_all
|
|
@user_sample = PerformanceSample.new(:user_id => user1.id, :service_type => "soundcloud", :service_id => "12345")
|
|
@user_sample.save!
|
|
end
|
|
|
|
context "when request is valid" do
|
|
it "should destroy successfully" do
|
|
ps_list = PerformanceSample.index({:id => user1.id})
|
|
ps_list.count.should == 1
|
|
ps_list.first.service_type.should == "soundcloud"
|
|
ps_list.first.service_id.should == "12345"
|
|
|
|
PerformanceSample.delete(user1, {:user_id => user1.id, :id => @user_sample.id})
|
|
|
|
ps_list = PerformanceSample.index({:id => user1.id})
|
|
ps_list.count.should == 0
|
|
end
|
|
end
|
|
|
|
context "when request is not valid" do
|
|
it "should raise PermissionError if requester id does not match id in request" do
|
|
lambda{PerformanceSample.delete(user2, {:user_id => user1.id, :id => @user_sample.id})}.should raise_error(PermissionError)
|
|
end
|
|
|
|
it "should raise error if user sample id is missing" do
|
|
lambda{PerformanceSample.delete(user1, {:user_id => user1.id})}.should raise_error(StateError)
|
|
end
|
|
end
|
|
end
|
|
end |