Skip to content
代码片段 群组 项目
提交 0b6bf9a1 编辑于 作者: Jonas Larsen's avatar Jonas Larsen 提交者: Sashi Kumar Kumaresan
浏览文件

Fix StandardContext test

上级 6880e362
No related branches found
No related tags found
无相关合并请求
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Gitlab::Tracking::StandardContext do
let_it_be(:project) { create(:project) }
let_it_be(:namespace) { create(:namespace) }
let_it_be(:plan) { :ultimate_plan }
let(:snowplow_context) { subject.to_context }
describe '#to_context' do
context 'plan' do
context 'when namespace is not available' do
it 'is nil' do
expect(snowplow_context.to_json.dig(:data, :plan)).to be_nil
end
end
context 'when namespace is available', :saas do
let(:namespace) { create(:namespace_with_plan, plan: plan) }
subject { described_class.new(namespace_id: namespace.id, plan_name: namespace.actual_plan_name) }
it 'contains plan name' do
expect(snowplow_context.to_json.dig(:data, :plan)).to eq(Plan::ULTIMATE)
end
end
end
end
end
...@@ -3,10 +3,6 @@ ...@@ -3,10 +3,6 @@
require 'spec_helper' require 'spec_helper'
RSpec.describe Gitlab::Tracking::StandardContext do RSpec.describe Gitlab::Tracking::StandardContext do
let_it_be(:project) { create(:project) }
let_it_be(:namespace) { create(:namespace) }
let_it_be(:user) { create(:user) }
let(:snowplow_context) { subject.to_context } let(:snowplow_context) { subject.to_context }
describe '#to_context' do describe '#to_context' do
...@@ -62,21 +58,27 @@ ...@@ -62,21 +58,27 @@
expect(snowplow_context.to_json.dig(:data, :context_generated_at)).to eq(Time.current) expect(snowplow_context.to_json.dig(:data, :context_generated_at)).to eq(Time.current)
end end
context 'plan' do it 'contains standard properties' do
context 'when namespace is not available' do standard_properties = [:user_id, :project_id, :namespace_id, :plan]
it 'is nil' do expect(snowplow_context.to_json[:data].keys).to include(*standard_properties)
expect(snowplow_context.to_json.dig(:data, :plan)).to be_nil end
end
end
context 'when namespace is available' do context 'with standard properties' do
let(:namespace) { create(:namespace) } let(:user_id) { 1 }
let(:project_id) { 2 }
let(:namespace_id) { 3 }
let(:plan_name) { "plan name" }
subject { described_class.new(namespace_id: namespace.id, plan_name: namespace.actual_plan_name) } subject do
described_class.new(user_id: user_id, project_id: project_id, namespace_id: namespace_id, plan_name: plan_name)
end
it 'contains plan name' do it 'holds the correct values', :aggregate_failures do
expect(snowplow_context.to_json.dig(:data, :plan)).to eq(Plan::DEFAULT) json_data = snowplow_context.to_json.fetch(:data)
end expect(json_data[:user_id]).to eq(user_id)
expect(json_data[:project_id]).to eq(project_id)
expect(json_data[:namespace_id]).to eq(namespace_id)
expect(json_data[:plan]).to eq(plan_name)
end end
end end
...@@ -95,24 +97,12 @@ ...@@ -95,24 +97,12 @@
end end
context 'with incorrect argument type' do context 'with incorrect argument type' do
subject { described_class.new(project_id: create(:group)) } subject { described_class.new(project_id: "a string") }
it 'does call `track_and_raise_for_dev_exception`' do it 'does call `track_and_raise_for_dev_exception`' do
expect(Gitlab::ErrorTracking).to receive(:track_and_raise_for_dev_exception) expect(Gitlab::ErrorTracking).to receive(:track_and_raise_for_dev_exception)
snowplow_context snowplow_context
end end
end end
it 'contains user id' do
expect(snowplow_context.to_json[:data].keys).to include(:user_id)
end
it 'contains namespace and project ids' do
expect(snowplow_context.to_json[:data].keys).to include(:project_id, :namespace_id)
end
it 'accepts just project id as integer' do
expect { described_class.new(project: 1).to_context }.not_to raise_error
end
end end
end end
0% 加载中 .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册