diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2020-09-19 04:45:44 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2020-09-19 04:45:44 +0300 |
commit | 85dc423f7090da0a52c73eb66faf22ddb20efff9 (patch) | |
tree | 9160f299afd8c80c038f08e1545be119f5e3f1e1 /spec/models/project_feature_usage_spec.rb | |
parent | 15c2c8c66dbe422588e5411eee7e68f1fa440bb8 (diff) |
Add latest changes from gitlab-org/gitlab@13-4-stable-ee
Diffstat (limited to 'spec/models/project_feature_usage_spec.rb')
-rw-r--r-- | spec/models/project_feature_usage_spec.rb | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/spec/models/project_feature_usage_spec.rb b/spec/models/project_feature_usage_spec.rb new file mode 100644 index 00000000000..908b98ee9c2 --- /dev/null +++ b/spec/models/project_feature_usage_spec.rb @@ -0,0 +1,59 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe ProjectFeatureUsage, type: :model do + describe '.jira_dvcs_integrations_enabled_count' do + it 'returns count of projects with Jira DVCS Cloud enabled' do + create(:project).feature_usage.log_jira_dvcs_integration_usage + create(:project).feature_usage.log_jira_dvcs_integration_usage + + expect(described_class.with_jira_dvcs_integration_enabled.count).to eq(2) + end + + it 'returns count of projects with Jira DVCS Server enabled' do + create(:project).feature_usage.log_jira_dvcs_integration_usage(cloud: false) + create(:project).feature_usage.log_jira_dvcs_integration_usage(cloud: false) + + expect(described_class.with_jira_dvcs_integration_enabled(cloud: false).count).to eq(2) + end + end + + describe '#log_jira_dvcs_integration_usage' do + let(:project) { create(:project) } + + subject { project.feature_usage } + + it 'logs Jira DVCS Cloud last sync' do + Timecop.freeze do + subject.log_jira_dvcs_integration_usage + + expect(subject.jira_dvcs_server_last_sync_at).to be_nil + expect(subject.jira_dvcs_cloud_last_sync_at).to be_like_time(Time.current) + end + end + + it 'logs Jira DVCS Server last sync' do + Timecop.freeze do + subject.log_jira_dvcs_integration_usage(cloud: false) + + expect(subject.jira_dvcs_server_last_sync_at).to be_like_time(Time.current) + expect(subject.jira_dvcs_cloud_last_sync_at).to be_nil + end + end + + context 'when log_jira_dvcs_integration_usage is called simultaneously for the same project' do + it 'logs the latest call' do + feature_usage = project.feature_usage + feature_usage.log_jira_dvcs_integration_usage + first_logged_at = feature_usage.jira_dvcs_cloud_last_sync_at + + Timecop.freeze(1.hour.from_now) do + ProjectFeatureUsage.new(project_id: project.id).log_jira_dvcs_integration_usage + end + + expect(feature_usage.reload.jira_dvcs_cloud_last_sync_at).to be > first_logged_at + end + end + end +end |