File: exposure_spec.rb

package info (click to toggle)
ruby-grape-entity 1.0.1-2
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 456 kB
  • sloc: ruby: 3,335; makefile: 6
file content (102 lines) | stat: -rw-r--r-- 4,293 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
# frozen_string_literal: true

require 'spec_helper'

describe Grape::Entity::Exposure do
  let(:fresh_class) { Class.new(Grape::Entity) }
  let(:model) { double(attributes) }
  let(:attributes) do
    {
      name: 'Bob Bobson',
      email: 'bob@example.com',
      birthday: Time.gm(2012, 2, 27),
      fantasies: ['Unicorns', 'Double Rainbows', 'Nessy'],
      characteristics: [
        { key: 'hair_color', value: 'brown' }
      ],
      friends: [
        double(name: 'Friend 1', email: 'friend1@example.com', characteristics: [], fantasies: [], birthday: Time.gm(2012, 2, 27), friends: []),
        double(name: 'Friend 2', email: 'friend2@example.com', characteristics: [], fantasies: [], birthday: Time.gm(2012, 2, 27), friends: [])
      ]
    }
  end
  let(:entity) { fresh_class.new(model) }
  subject { fresh_class.find_exposure(:name) }

  describe '#key' do
    it 'returns the attribute if no :as is set' do
      fresh_class.expose :name
      expect(subject.key(entity)).to eq :name
    end

    it 'returns the :as alias if one exists' do
      fresh_class.expose :name, as: :nombre
      expect(subject.key(entity)).to eq :nombre
    end

    it 'returns the result if :as is a proc' do
      fresh_class.expose :name, as: proc { object.name.reverse }
      expect(subject.key(entity)).to eq(model.name.reverse)
    end

    it 'returns the result if :as is a lambda' do
      fresh_class.expose :name, as: ->(obj, _opts) { obj.name.reverse }
      expect(subject.key(entity)).to eq(model.name.reverse)
    end
  end

  describe '#conditions_met?' do
    it 'only passes through hash :if exposure if all attributes match' do
      fresh_class.expose :name, if: { condition1: true, condition2: true }

      expect(subject.conditions_met?(entity, {})).to be false
      expect(subject.conditions_met?(entity, condition1: true)).to be false
      expect(subject.conditions_met?(entity, condition1: true, condition2: true)).to be true
      expect(subject.conditions_met?(entity, condition1: false, condition2: true)).to be false
      expect(subject.conditions_met?(entity, condition1: true, condition2: true, other: true)).to be true
    end

    it 'looks for presence/truthiness if a symbol is passed' do
      fresh_class.expose :name, if: :condition1

      expect(subject.conditions_met?(entity, {})).to be false
      expect(subject.conditions_met?(entity, condition1: true)).to be true
      expect(subject.conditions_met?(entity, condition1: false)).to be false
      expect(subject.conditions_met?(entity, condition1: nil)).to be false
    end

    it 'looks for absence/falsiness if a symbol is passed' do
      fresh_class.expose :name, unless: :condition1

      expect(subject.conditions_met?(entity, {})).to be true
      expect(subject.conditions_met?(entity, condition1: true)).to be false
      expect(subject.conditions_met?(entity, condition1: false)).to be true
      expect(subject.conditions_met?(entity, condition1: nil)).to be true
    end

    it 'only passes through proc :if exposure if it returns truthy value' do
      fresh_class.expose :name, if: ->(_, opts) { opts[:true] }

      expect(subject.conditions_met?(entity, true: false)).to be false
      expect(subject.conditions_met?(entity, true: true)).to be true
    end

    it 'only passes through hash :unless exposure if any attributes do not match' do
      fresh_class.expose :name, unless: { condition1: true, condition2: true }

      expect(subject.conditions_met?(entity, {})).to be true
      expect(subject.conditions_met?(entity, condition1: true)).to be true
      expect(subject.conditions_met?(entity, condition1: true, condition2: true)).to be false
      expect(subject.conditions_met?(entity, condition1: false, condition2: true)).to be true
      expect(subject.conditions_met?(entity, condition1: true, condition2: true, other: true)).to be false
      expect(subject.conditions_met?(entity, condition1: false, condition2: false)).to be true
    end

    it 'only passes through proc :unless exposure if it returns falsy value' do
      fresh_class.expose :name, unless: ->(_, opts) { opts[:true] == true }

      expect(subject.conditions_met?(entity, true: false)).to be true
      expect(subject.conditions_met?(entity, true: true)).to be false
    end
  end
end