53 lines
1.6 KiB
Ruby
53 lines
1.6 KiB
Ruby
describe APIParticulier::Services::SourcesService do
|
||
let(:service) { described_class.new(procedure) }
|
||
|
||
let(:procedure) { create(:procedure) }
|
||
let(:api_particulier_scopes) { [] }
|
||
let(:api_particulier_sources) { {} }
|
||
|
||
before do
|
||
procedure.update(api_particulier_scopes: api_particulier_scopes)
|
||
procedure.update(api_particulier_sources: api_particulier_sources)
|
||
end
|
||
|
||
describe "#available_sources" do
|
||
subject { service.available_sources }
|
||
|
||
context 'when the procedure doesn’t have any available scopes' do
|
||
it { is_expected.to eq({}) }
|
||
end
|
||
|
||
context 'when a procedure has a cnaf_allocataires and a cnaf_adresse scopes' do
|
||
let(:api_particulier_scopes) { ['cnaf_allocataires', 'cnaf_enfants'] }
|
||
|
||
let(:cnaf_allocataires_and_enfants) do
|
||
{
|
||
'cnaf' => {
|
||
'allocataires' => ['nomPrenom', 'dateDeNaissance', 'sexe'],
|
||
'enfants' => ['nomPrenom', 'dateDeNaissance', 'sexe']
|
||
}
|
||
}
|
||
end
|
||
|
||
it { is_expected.to match(cnaf_allocataires_and_enfants) }
|
||
end
|
||
end
|
||
|
||
describe '#sanitize' do
|
||
subject { service.sanitize(requested_sources) }
|
||
|
||
let(:api_particulier_scopes) { ['cnaf_allocataires', 'cnaf_adresse'] }
|
||
let(:requested_sources) do
|
||
{
|
||
'cnaf' => {
|
||
'allocataires' => ['nomPrenom', 'forbidden_sources', { 'weird_object' => 1 }],
|
||
'forbidden_scope' => ['any_source'],
|
||
'adresse' => { 'weird_object' => 1 }
|
||
},
|
||
'forbidden_provider' => { 'anything_scope' => ['any_source'] }
|
||
}
|
||
end
|
||
|
||
it { is_expected.to eq({ 'cnaf' => { 'allocataires' => ['nomPrenom'] } }) }
|
||
end
|
||
end
|