Commit 3f421a01 authored by Ash McKenzie's avatar Ash McKenzie

Update Actor::Username, add specs

parent 5663f7a1
require_relative 'base' require_relative 'base'
require_relative 'key'
module Actor module Actor
class Username < Base class Username < Key
alias username identifier
def self.identifier_prefix def self.identifier_prefix
'username'.freeze 'username'.freeze
end end
...@@ -13,7 +12,14 @@ module Actor ...@@ -13,7 +12,14 @@ module Actor
end end
def self.id_regex def self.id_regex
/\Ausername\-\d+\Z/ /\Ausername\-[a-z0-9-]+\z/
end
private
# Override Base#label
def label
'user'
end end
end end
end end
...@@ -33,7 +33,7 @@ class GitlabShell ...@@ -33,7 +33,7 @@ class GitlabShell
end end
parsed_command = parse_cmd(origin_cmd) parsed_command = parse_cmd(origin_cmd)
action = determine_action(parsed_command) # FIXME: watch out action = determine_action(parsed_command)
action.execute(parsed_command.command, parsed_command.args) action.execute(parsed_command.command, parsed_command.args)
rescue GitlabNet::ApiUnreachableError rescue GitlabNet::ApiUnreachableError
$stderr.puts "GitLab: Failed to authorize your Git request: internal API unreachable" $stderr.puts "GitLab: Failed to authorize your Git request: internal API unreachable"
......
require_relative '../spec_helper'
require_relative '../../lib/actor/username'
describe Actor::Username do
let(:username) { 'testuser' }
let(:api) { double(GitlabNet) }
let(:discover_payload) { { 'username' => username } }
let(:audit_usernames) { nil }
before do
allow(GitlabNet).to receive(:new).and_return(api)
allow(api).to receive(:discover).with(subject).and_return(discover_payload)
end
describe '.from' do
it 'returns an instance of Actor::Username' do
expect(described_class.from("username-#{username}")).to be_a(Actor::Username)
end
it 'has an id == 1' do
expect(described_class.from('username-1').id).to eq '1'
end
end
describe '.identifier_prefix' do
it "returns 'user'" do
expect(described_class.identifier_prefix).to eql 'username'
end
end
describe '.identifier_key' do
it "returns 'username'" do
expect(described_class.identifier_key).to eql 'username'
end
end
subject { described_class.new(username, audit_usernames: audit_usernames) }
describe '#username' do
context 'without a valid user' do
it "returns '@testuser'" do
expect(subject.username).to eql "@#{username}"
end
end
context 'without a valid user' do
let(:discover_payload) { nil }
it "returns 'Anonymous'" do
expect(subject.username).to eql 'Anonymous'
end
end
end
describe '#identifier' do
it "returns 'username-testuser'" do
expect(subject.identifier).to eql 'username-testuser'
end
end
describe '#log_username' do
context 'when audit_usernames is true' do
let(:audit_usernames) { true }
it "returns '@testuser'" do
expect(subject.log_username).to eql "@#{username}"
end
end
context 'when audit_usernames is false' do
let(:audit_usernames) { false }
it "returns 'user with identifier username-testuser'" do
expect(subject.log_username).to eql "user with identifier username-#{username}"
end
end
end
end
...@@ -23,6 +23,12 @@ describe Actor do ...@@ -23,6 +23,12 @@ describe Actor do
expect(described_class.new_from('user-1')).to be_a(Actor::User) expect(described_class.new_from('user-1')).to be_a(Actor::User)
end end
end end
context 'of Username' do
it 'returns an instance of Username' do
expect(described_class.new_from('username-john1')).to be_a(Actor::Username)
end
end
end end
end end
end end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment