Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2023-08-23 18:11:20 +0300
committerGitLab Bot <gitlab-bot@gitlab.com>2023-08-23 18:11:20 +0300
commit9919ffe0c8760e1e19e068d67a5ae6ae8aa67c5d (patch)
tree200b534b89d0fb4c574e7398ba975485d28f1d5a /spec/models/clusters
parent41fb807ff49f759a25e7db51a61a1356ff41ed4b (diff)
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/models/clusters')
-rw-r--r--spec/models/clusters/agent_token_spec.rb32
1 files changed, 28 insertions, 4 deletions
diff --git a/spec/models/clusters/agent_token_spec.rb b/spec/models/clusters/agent_token_spec.rb
index 41f8215b713..932a1f213fd 100644
--- a/spec/models/clusters/agent_token_spec.rb
+++ b/spec/models/clusters/agent_token_spec.rb
@@ -2,7 +2,7 @@
require 'spec_helper'
-RSpec.describe Clusters::AgentToken do
+RSpec.describe Clusters::AgentToken, feature_category: :deployment_management do
it { is_expected.to belong_to(:agent).class_name('Clusters::Agent').required }
it { is_expected.to belong_to(:created_by_user).class_name('User').optional }
it { is_expected.to validate_length_of(:description).is_at_most(1024) }
@@ -12,8 +12,9 @@ RSpec.describe Clusters::AgentToken do
it_behaves_like 'having unique enum values'
describe 'scopes' do
+ let_it_be(:agent) { create(:cluster_agent) }
+
describe '.order_last_used_at_desc' do
- let_it_be(:agent) { create(:cluster_agent) }
let_it_be(:token_1) { create(:cluster_agent_token, agent: agent, last_used_at: 7.days.ago) }
let_it_be(:token_2) { create(:cluster_agent_token, agent: agent, last_used_at: nil) }
let_it_be(:token_3) { create(:cluster_agent_token, agent: agent, last_used_at: 2.days.ago) }
@@ -25,8 +26,8 @@ RSpec.describe Clusters::AgentToken do
end
describe 'status-related scopes' do
- let!(:active_token) { create(:cluster_agent_token) }
- let!(:revoked_token) { create(:cluster_agent_token, :revoked) }
+ let!(:active_token) { create(:cluster_agent_token, agent: agent) }
+ let!(:revoked_token) { create(:cluster_agent_token, :revoked, agent: agent) }
describe '.with_status' do
context 'when filtering by active status' do
@@ -48,6 +49,29 @@ RSpec.describe Clusters::AgentToken do
it { is_expected.to contain_exactly(active_token) }
end
end
+
+ describe '.connected' do
+ let!(:token) { create(:cluster_agent_token, agent: agent, status: status, last_used_at: last_used_at) }
+
+ let(:status) { :active }
+ let(:last_used_at) { 2.minutes.ago }
+
+ subject { described_class.connected }
+
+ it { is_expected.to contain_exactly(token) }
+
+ context 'when the token has not been used recently' do
+ let(:last_used_at) { 2.hours.ago }
+
+ it { is_expected.to be_empty }
+ end
+
+ context 'when the token is not active' do
+ let(:status) { :revoked }
+
+ it { is_expected.to be_empty }
+ end
+ end
end
describe '#token' do