blob: 691e19f638014ff427edcfddb51cab3b03a45e8b (
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
|
# frozen_string_literal: true
require "spec_helper"
describe Bundler::Fetcher::CompactIndex do
let(:downloader) { double(:downloader) }
let(:remote) { double(:remote, :cache_slug => "lsjdf") }
let(:display_uri) { URI("http://sampleuri.com") }
let(:compact_index) { described_class.new(downloader, remote, display_uri) }
before do
allow(compact_index).to receive(:log_specs) {}
end
describe "#specs_for_names" do
it "has only one thread open at the end of the run" do
compact_index.specs_for_names(["lskdjf"])
thread_count = Thread.list.count {|thread| thread.status == "run" }
expect(thread_count).to eq 1
end
it "calls worker#stop during the run" do
expect_any_instance_of(Bundler::Worker).to receive(:stop).at_least(:once)
compact_index.specs_for_names(["lskdjf"])
end
describe "#available?" do
context "when OpenSSL is in FIPS mode", :ruby => ">= 2.0.0" do
before { stub_const("OpenSSL::OPENSSL_FIPS", true) }
it "returns false" do
expect(compact_index).to_not be_available
end
it "never requires digest/md5" do
expect(Kernel).to receive(:require).with("digest/md5").never
compact_index.available?
end
end
end
context "logging" do
before { allow(compact_index).to receive(:log_specs).and_call_original }
context "with debug on" do
before do
allow(Bundler).to receive_message_chain(:ui, :debug?).and_return(true)
end
it "should log at info level" do
expect(Bundler).to receive_message_chain(:ui, :debug).with('Looking up gems ["lskdjf"]')
compact_index.specs_for_names(["lskdjf"])
end
end
context "with debug off" do
before do
allow(Bundler).to receive_message_chain(:ui, :debug?).and_return(false)
end
it "should log at info level" do
expect(Bundler).to receive_message_chain(:ui, :info).with(".", false)
compact_index.specs_for_names(["lskdjf"])
end
end
end
end
end
|