debian-mirror-gitlab/spec/requests/api/statistics_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

94 lines
2.5 KiB
Ruby
Raw Permalink Normal View History

2019-12-04 20:38:33 +05:30
# frozen_string_literal: true
require 'spec_helper'
2023-06-20 00:43:36 +05:30
RSpec.describe API::Statistics, 'Statistics', :aggregate_failures, feature_category: :devops_reports do
2019-12-04 20:38:33 +05:30
include ProjectForksHelper
2020-05-24 23:13:21 +05:30
tables_to_analyze = %w[
2019-12-04 20:38:33 +05:30
projects
users
namespaces
issues
merge_requests
notes
snippets
fork_networks
fork_network_members
keys
milestones
].freeze
let(:path) { "/application/statistics" }
describe "GET /application/statistics" do
2023-06-20 00:43:36 +05:30
it_behaves_like 'GET request permissions for admin mode'
2019-12-04 20:38:33 +05:30
context 'when no user' do
it "returns authentication error" do
get api(path, nil)
2020-04-08 14:13:33 +05:30
expect(response).to have_gitlab_http_status(:unauthorized)
2019-12-04 20:38:33 +05:30
end
end
context "when not an admin" do
let(:user) { create(:user) }
it "returns forbidden error" do
get api(path, user)
2020-04-08 14:13:33 +05:30
expect(response).to have_gitlab_http_status(:forbidden)
2019-12-04 20:38:33 +05:30
end
end
context 'when authenticated as admin' do
let(:admin) { create(:admin) }
it 'matches the response schema' do
2023-06-20 00:43:36 +05:30
get api(path, admin, admin_mode: true)
2019-12-04 20:38:33 +05:30
2020-04-08 14:13:33 +05:30
expect(response).to have_gitlab_http_status(:ok)
2019-12-04 20:38:33 +05:30
expect(response).to match_response_schema('statistics')
end
it 'gives the right statistics' do
projects = create_list(:project, 4, namespace: create(:namespace, owner: admin))
issues = create_list(:issue, 2, project: projects.first, updated_by: admin)
create_list(:snippet, 2, :public, author: admin)
create_list(:note, 2, author: admin, project: projects.first, noteable: issues.first)
create_list(:milestone, 3, project: projects.first)
create(:key, user: admin)
create(:merge_request, source_project: projects.first)
fork_project(projects.first, admin)
# Make sure the reltuples have been updated
# to get a correct count on postgresql
2020-05-24 23:13:21 +05:30
tables_to_analyze.each do |table|
2021-10-27 15:23:28 +05:30
ApplicationRecord.connection.execute("ANALYZE #{table}")
2019-12-04 20:38:33 +05:30
end
2023-06-20 00:43:36 +05:30
get api(path, admin, admin_mode: true)
2019-12-04 20:38:33 +05:30
expected_statistics = {
issues: 2,
merge_requests: 1,
notes: 2,
snippets: 2,
forks: 1,
ssh_keys: 1,
milestones: 3,
users: 1,
projects: 5,
groups: 1,
active_users: 1
}
expected_statistics.each do |entity, count|
expect(json_response[entity.to_s]).to eq(count.to_s)
end
end
end
end
end