summaryrefslogtreecommitdiff
path: root/spec/gitlab_shell_personal_access_token_spec.rb
diff options
context:
space:
mode:
authorTaylan Develioglu <taylan.develioglu@booking.com>2020-07-06 14:09:55 +0200
committerTaylan Develioglu <taylan.develioglu@booking.com>2020-08-17 17:16:06 +0200
commitb8d66d7923150402f54f13d793d3051efab3a832 (patch)
treedd67dbef7c4c06e3a1ac5cf981be9ee37d355a03 /spec/gitlab_shell_personal_access_token_spec.rb
parent4b1ee791a1bdc927becee37ae84f7ba226d17791 (diff)
downloadgitlab-shell-b8d66d7923150402f54f13d793d3051efab3a832.tar.gz
Add support obtaining personal access tokens via SSH
Implements the feature requested in gitlab-org/gitlab#19672 This requires the internal api counterpart in gitlab-org/gitlab!36302 to be merged first. It can be used as follows: ``` censored@censored-VirtualBox:~/git/gitlab$ ssh git@gitlab-2004 personal_access_token remote: remote: ======================================================================== remote: remote: Usage: personal_access_token <name> <scope1[,scope2,...]> [ttl_days] remote: remote: ======================================================================== remote: censored@censored-VirtualBox:~/git/gitlab$ ssh git@gitlab-2004 personal_access_token newtoken read_api,read_repository 30 Token: aAY1G3YPeemECgUvxuXY Scopes: read_api,read_repository Expires: 2020-08-07 ```
Diffstat (limited to 'spec/gitlab_shell_personal_access_token_spec.rb')
-rw-r--r--spec/gitlab_shell_personal_access_token_spec.rb119
1 files changed, 119 insertions, 0 deletions
diff --git a/spec/gitlab_shell_personal_access_token_spec.rb b/spec/gitlab_shell_personal_access_token_spec.rb
new file mode 100644
index 0000000..64bc34b
--- /dev/null
+++ b/spec/gitlab_shell_personal_access_token_spec.rb
@@ -0,0 +1,119 @@
+require_relative 'spec_helper'
+
+require 'json'
+require 'open3'
+
+describe 'bin/gitlab-shell personal_access_token' do
+ include_context 'gitlab shell'
+
+ before(:context) do
+ write_config("gitlab_url" => "http+unix://#{CGI.escape(tmp_socket_path)}")
+ end
+
+ def mock_server(server)
+ server.mount_proc('/api/v4/internal/personal_access_token') do |req, res|
+ params = JSON.parse(req.body)
+
+ res.content_type = 'application/json'
+ res.status = 200
+
+ if params['key_id'] == '000'
+ res.body = { success: false, message: "Something wrong!"}.to_json
+ else
+ res.body = {
+ success: true,
+ token: 'aAY1G3YPeemECgUvxuXY',
+ scopes: params['scopes'],
+ expires_at: (params['expires_at'] && '9001-12-01')
+ }.to_json
+ end
+ end
+
+ server.mount_proc('/api/v4/internal/discover') do |req, res|
+ res.status = 200
+ res.content_type = 'application/json'
+ res.body = '{"id":100, "name": "Some User", "username": "someuser"}'
+ end
+ end
+
+ describe 'command' do
+ let(:key_id) { 'key-100' }
+
+ let(:output) do
+ env = {
+ 'SSH_CONNECTION' => 'fake',
+ 'SSH_ORIGINAL_COMMAND' => "personal_access_token #{args}"
+ }
+ Open3.popen2e(env, "#{gitlab_shell_path} #{key_id}")[1].read()
+ end
+
+ let(:help_message) do
+ <<~OUTPUT
+ remote:
+ remote: ========================================================================
+ remote:
+ remote: Usage: personal_access_token <name> <scope1[,scope2,...]> [ttl_days]
+ remote:
+ remote: ========================================================================
+ remote:
+ OUTPUT
+ end
+
+ context 'without any arguments' do
+ let(:args) { '' }
+
+ it 'prints the help message' do
+ expect(output).to eq(help_message)
+ end
+ end
+
+ context 'with only the name argument' do
+ let(:args) { 'newtoken' }
+
+ it 'prints the help message' do
+ expect(output).to eq(help_message)
+ end
+ end
+
+ context 'without a ttl argument' do
+ let(:args) { 'newtoken api' }
+
+ it 'prints a token without an expiration date' do
+ expect(output).to eq(<<~OUTPUT)
+ Token: aAY1G3YPeemECgUvxuXY
+ Scopes: api
+ Expires: never
+ OUTPUT
+ end
+ end
+
+ context 'with a ttl argument' do
+ let(:args) { 'newtoken read_api,read_user 30' }
+
+ it 'prints a token with an expiration date' do
+ expect(output).to eq(<<~OUTPUT)
+ Token: aAY1G3YPeemECgUvxuXY
+ Scopes: read_api,read_user
+ Expires: 9001-12-01
+ OUTPUT
+ end
+ end
+
+ context 'with an API error response' do
+ let(:args) { 'newtoken api' }
+ let(:key_id) { 'key-000' }
+
+ it 'prints the error response' do
+ expect(output).to eq(<<~OUTPUT)
+ remote:
+ remote: ========================================================================
+ remote:
+ remote: Something wrong!
+ remote:
+ remote: ========================================================================
+ remote:
+ OUTPUT
+ end
+ end
+ end
+end