blob: 52fb4e7f1c19599efaaeb78ecfb28f5de9575e05 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
|
# frozen_string_literal: true
require "bundler/source/rubygems/remote"
RSpec.describe Bundler::Source::Rubygems::Remote do
def remote(uri)
Bundler::Source::Rubygems::Remote.new(uri)
end
before do
allow(Digest(:MD5)).to receive(:hexdigest).with(duck_type(:to_s)) {|string| "MD5HEX(#{string})" }
end
let(:uri_no_auth) { URI("https://gems.example.com") }
let(:uri_with_auth) { URI("https://#{credentials}@gems.example.com") }
let(:credentials) { "username:password" }
context "when the original URI has no credentials" do
describe "#uri" do
it "returns the original URI" do
expect(remote(uri_no_auth).uri).to eq(uri_no_auth)
end
it "applies configured credentials" do
Bundler.settings.temporary(uri_no_auth.to_s => credentials) do
expect(remote(uri_no_auth).uri).to eq(uri_with_auth)
end
end
end
describe "#anonymized_uri" do
it "returns the original URI" do
expect(remote(uri_no_auth).anonymized_uri).to eq(uri_no_auth)
end
it "does not apply given credentials" do
Bundler.settings.temporary(uri_no_auth.to_s => credentials) do
expect(remote(uri_no_auth).anonymized_uri).to eq(uri_no_auth)
end
end
end
describe "#cache_slug" do
it "returns the correct slug" do
expect(remote(uri_no_auth).cache_slug).to eq("gems.example.com.443.MD5HEX(gems.example.com.443./)")
end
it "only applies the given user" do
Bundler.settings.temporary(uri_no_auth.to_s => credentials) do
expect(remote(uri_no_auth).cache_slug).to eq("gems.example.com.username.443.MD5HEX(gems.example.com.username.443./)")
end
end
end
end
context "when the original URI has a username and password" do
describe "#uri" do
it "returns the original URI" do
expect(remote(uri_with_auth).uri).to eq(uri_with_auth)
end
it "does not apply configured credentials" do
Bundler.settings.temporary(uri_no_auth.to_s => "other:stuff")
expect(remote(uri_with_auth).uri).to eq(uri_with_auth)
end
end
describe "#anonymized_uri" do
it "returns the URI without username and password" do
expect(remote(uri_with_auth).anonymized_uri).to eq(uri_no_auth)
end
it "does not apply given credentials" do
Bundler.settings.temporary(uri_no_auth.to_s => "other:stuff")
expect(remote(uri_with_auth).anonymized_uri).to eq(uri_no_auth)
end
end
describe "#cache_slug" do
it "returns the correct slug" do
expect(remote(uri_with_auth).cache_slug).to eq("gems.example.com.username.443.MD5HEX(gems.example.com.username.443./)")
end
it "does not apply given credentials" do
Bundler.settings.temporary(uri_with_auth.to_s => credentials)
expect(remote(uri_with_auth).cache_slug).to eq("gems.example.com.username.443.MD5HEX(gems.example.com.username.443./)")
end
end
end
context "when the original URI has only a username" do
let(:uri) { URI("https://SeCrEt-ToKeN@gem.fury.io/me/") }
describe "#anonymized_uri" do
it "returns the URI without username and password" do
expect(remote(uri).anonymized_uri).to eq(URI("https://gem.fury.io/me/"))
end
end
describe "#cache_slug" do
it "returns the correct slug" do
expect(remote(uri).cache_slug).to eq("gem.fury.io.SeCrEt-ToKeN.443.MD5HEX(gem.fury.io.SeCrEt-ToKeN.443./me/)")
end
end
end
context "when a mirror with inline credentials is configured for the URI" do
let(:uri) { URI("https://rubygems.org/") }
let(:mirror_uri_with_auth) { URI("https://username:password@rubygems-mirror.org/") }
let(:mirror_uri_no_auth) { URI("https://rubygems-mirror.org/") }
before { Bundler.settings.temporary("mirror.https://rubygems.org/" => mirror_uri_with_auth.to_s) }
after { Bundler.settings.temporary("mirror.https://rubygems.org/" => nil) }
specify "#uri returns the mirror URI with credentials" do
expect(remote(uri).uri).to eq(mirror_uri_with_auth)
end
specify "#anonymized_uri returns the mirror URI without credentials" do
expect(remote(uri).anonymized_uri).to eq(mirror_uri_no_auth)
end
specify "#original_uri returns the original source" do
expect(remote(uri).original_uri).to eq(uri)
end
specify "#cache_slug returns the correct slug" do
expect(remote(uri).cache_slug).to eq("rubygems.org.443.MD5HEX(rubygems.org.443./)")
end
end
context "when a mirror with configured credentials is configured for the URI" do
let(:uri) { URI("https://rubygems.org/") }
let(:mirror_uri_with_auth) { URI("https://#{credentials}@rubygems-mirror.org/") }
let(:mirror_uri_no_auth) { URI("https://rubygems-mirror.org/") }
before do
Bundler.settings.temporary("mirror.https://rubygems.org/" => mirror_uri_no_auth.to_s)
Bundler.settings.temporary(mirror_uri_no_auth.to_s => credentials)
end
after do
Bundler.settings.temporary("mirror.https://rubygems.org/" => nil)
Bundler.settings.temporary(mirror_uri_no_auth.to_s => nil)
end
specify "#uri returns the mirror URI with credentials" do
expect(remote(uri).uri).to eq(mirror_uri_with_auth)
end
specify "#anonymized_uri returns the mirror URI without credentials" do
expect(remote(uri).anonymized_uri).to eq(mirror_uri_no_auth)
end
specify "#original_uri returns the original source" do
expect(remote(uri).original_uri).to eq(uri)
end
specify "#cache_slug returns the original source" do
expect(remote(uri).cache_slug).to eq("rubygems.org.443.MD5HEX(rubygems.org.443./)")
end
end
context "when there is no mirror set" do
describe "#original_uri" do
it "is not set" do
expect(remote(uri_no_auth).original_uri).to be_nil
end
end
end
end
|