aboutsummaryrefslogtreecommitdiffstats
path: root/spec/bundler/install/yanked_spec.rb
blob: d42978ce4c1bacd9c7ccc9a3b4b85e7a127bf61e (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
# frozen_string_literal: true
require "spec_helper"

RSpec.context "when installing a bundle that includes yanked gems" do
  before(:each) do
    build_repo4 do
      build_gem "foo", "9.0.0"
    end
  end

  it "throws an error when the original gem version is yanked" do
    lockfile <<-L
       GEM
         remote: file://#{gem_repo4}
         specs:
           foo (10.0.0)

       PLATFORMS
         ruby

       DEPENDENCIES
         foo (= 10.0.0)

    L

    install_gemfile <<-G
        source "file://#{gem_repo4}"
        gem "foo", "10.0.0"
    G

    expect(out).to include("Your bundle is locked to foo (10.0.0)")
  end

  it "throws the original error when only the Gemfile specifies a gem version that doesn't exist" do
    install_gemfile <<-G
        source "file://#{gem_repo4}"
        gem "foo", "10.0.0"
    G

    expect(out).not_to include("Your bundle is locked to foo (10.0.0)")
    expect(out).to include("Could not find gem 'foo (= 10.0.0)' in any of the gem sources")
  end
end

RSpec.context "when using gem before installing" do
  it "does not suggest the author has yanked the gem" do
    gemfile <<-G
        source "file://#{gem_repo1}"
        gem "rack", "0.9.1"
    G

    lockfile <<-L
       GEM
         remote: file://#{gem_repo1}
         specs:
           rack (0.9.1)

       PLATFORMS
         ruby

       DEPENDENCIES
         rack (= 0.9.1)
    L

    bundle :list

    expect(out).to include("Could not find rack-0.9.1 in any of the sources")
    expect(out).to_not include("Your bundle is locked to rack (0.9.1), but that version could not be found in any of the sources listed in your Gemfile.")
    expect(out).to_not include("If you haven't changed sources, that means the author of rack (0.9.1) has removed it.")
    expect(out).to_not include("You'll need to update your bundle to a different version of rack (0.9.1) that hasn't been removed in order to install.")
  end
end