summaryrefslogtreecommitdiff
path: root/spec/presenters
diff options
context:
space:
mode:
authorRémy Coutable <remy@rymai.me>2017-01-09 21:45:49 +0100
committerRémy Coutable <remy@rymai.me>2017-01-18 16:38:34 +0100
commitbf789ff567c71ff68c216bfa8f3d43e09b6f49fb (patch)
tree28d4ac2aa74824eb5d85dc8271474980a3237bbe /spec/presenters
parentfd72c0f4c748658f539d24a286366e9ac7a22b57 (diff)
downloadgitlab-ce-bf789ff567c71ff68c216bfa8f3d43e09b6f49fb.tar.gz
Improve presenter architecture
Signed-off-by: Rémy Coutable <remy@rymai.me>
Diffstat (limited to 'spec/presenters')
-rw-r--r--spec/presenters/build_presenter_spec.rb35
-rw-r--r--spec/presenters/ci/build/presenter_spec.rb75
-rw-r--r--spec/presenters/ci/variable/presenter_spec.rb23
-rw-r--r--spec/presenters/variable_presenter_spec.rb23
4 files changed, 98 insertions, 58 deletions
diff --git a/spec/presenters/build_presenter_spec.rb b/spec/presenters/build_presenter_spec.rb
deleted file mode 100644
index fa7b0567622..00000000000
--- a/spec/presenters/build_presenter_spec.rb
+++ /dev/null
@@ -1,35 +0,0 @@
-require 'spec_helper'
-
-describe BuildPresenter do
- let(:build) { create(:ci_build) }
- subject do
- described_class.new(build).with_subject(build)
- end
-
- describe '#initialize' do
- it 'takes a build and optional params' do
- expect { subject }.
- not_to raise_error
- end
-
- it 'exposes build' do
- expect(subject.build).to eq(build)
- end
-
- it 'forwards missing methods to build' do
- expect(subject.ref).to eq('master')
- end
- end
-
- describe '#erased_by_user?' do
- it 'takes a build and optional params' do
- expect(subject).not_to be_erased_by_user
- end
- end
-
- describe 'quack like a Ci::Build' do
- it 'takes a build and optional params' do
- expect(described_class.ancestors).to include(Ci::Build)
- end
- end
-end
diff --git a/spec/presenters/ci/build/presenter_spec.rb b/spec/presenters/ci/build/presenter_spec.rb
new file mode 100644
index 00000000000..ecab84dcbc9
--- /dev/null
+++ b/spec/presenters/ci/build/presenter_spec.rb
@@ -0,0 +1,75 @@
+require 'spec_helper'
+
+describe Ci::Build::Presenter do
+ let(:project) { create(:empty_project) }
+ let(:pipeline) { create(:ci_pipeline, project: project) }
+ let(:build) { create(:ci_build, pipeline: pipeline) }
+
+ subject do
+ described_class.new(build)
+ end
+
+ it 'inherits from Gitlab::View::Presenter::Delegated' do
+ expect(described_class.superclass).to eq(Gitlab::View::Presenter::Delegated)
+ end
+
+ describe '#initialize' do
+ it 'takes a build and optional params' do
+ expect { subject }.not_to raise_error
+ end
+
+ it 'exposes build' do
+ expect(subject.build).to eq(build)
+ end
+
+ it 'forwards missing methods to build' do
+ expect(subject.ref).to eq('master')
+ end
+ end
+
+ describe '#erased_by_user?' do
+ it 'takes a build and optional params' do
+ expect(subject).not_to be_erased_by_user
+ end
+ end
+
+ describe '#erased_by_name' do
+ context 'when build is not erased' do
+ before do
+ expect(build).to receive(:erased_by).and_return(nil)
+ end
+
+ it 'returns nil' do
+ expect(subject.erased_by_name).to be_nil
+ end
+ end
+ context 'when build is erased' do
+ before do
+ expect(build).to receive(:erased_by).twice.
+ and_return(double(:user, name: 'John Doe'))
+ end
+
+ it 'returns the name of the eraser' do
+ expect(subject.erased_by_name).to eq('John Doe')
+ end
+ end
+ end
+
+ describe 'quack like a Ci::Build permission-wise' do
+ context 'user is not allowed' do
+ let(:project) { create(:empty_project, public_builds: false) }
+
+ it 'returns false' do
+ expect(subject.can?(nil, :read_build)).to be_falsy
+ end
+ end
+
+ context 'user is allowed' do
+ let(:project) { create(:empty_project, :public) }
+
+ it 'returns true' do
+ expect(subject.can?(nil, :read_build)).to be_truthy
+ end
+ end
+ end
+end
diff --git a/spec/presenters/ci/variable/presenter_spec.rb b/spec/presenters/ci/variable/presenter_spec.rb
new file mode 100644
index 00000000000..b3afb2e2e33
--- /dev/null
+++ b/spec/presenters/ci/variable/presenter_spec.rb
@@ -0,0 +1,23 @@
+require 'spec_helper'
+
+describe Ci::Variable::Presenter do
+ let(:variable) { double(:variable) }
+
+ subject do
+ described_class.new(variable)
+ end
+
+ it 'inherits from Gitlab::View::Presenter::Simple' do
+ expect(described_class.superclass).to eq(Gitlab::View::Presenter::Simple)
+ end
+
+ describe '#initialize' do
+ it 'takes a variable and optional params' do
+ expect { subject }.not_to raise_error
+ end
+
+ it 'exposes variable' do
+ expect(subject.variable).to eq(variable)
+ end
+ end
+end
diff --git a/spec/presenters/variable_presenter_spec.rb b/spec/presenters/variable_presenter_spec.rb
deleted file mode 100644
index f09a0c922ae..00000000000
--- a/spec/presenters/variable_presenter_spec.rb
+++ /dev/null
@@ -1,23 +0,0 @@
-require 'spec_helper'
-
-describe VariablePresenter do
- let(:variable) { double(:variable, foo: 'bar') }
- subject do
- described_class.new.with_subject(variable)
- end
-
- describe '#initialize' do
- it 'takes a variable and optional params' do
- expect { subject }.
- not_to raise_error
- end
-
- it 'exposes variable' do
- expect(subject.variable).to eq(variable)
- end
-
- it 'does not forward missing methods to variable' do
- expect { subject.foo }.to raise_error(NoMethodError)
- end
- end
-end