summaryrefslogtreecommitdiff
path: root/spec/integration/knife/data_bag_show_spec.rb
blob: 35f12f9619ab93b18162c8509bab8d9136216133 (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
#
# Copyright:: Copyright 2013-2016, Chef Software Inc.
# License:: Apache License, Version 2.0
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

require "support/shared/integration/integration_helper"
require "support/shared/context/config"
require "chef/knife/data_bag_show"

describe "knife data bag show", :workstation do
  include IntegrationSupport
  include KnifeSupport

  include_context "default config options"

  when_the_chef_server "is empty" do
    it "raises error if try to retrieve it" do
      expect { knife("data bag show bag") }.to raise_error(Net::HTTPClientException)
    end
  end

  when_the_chef_server "contains data bags" do
    let(:right_secret) { "abc" }
    let(:wrong_secret) { "ab" }
    let(:err) { "Encrypted data bag detected, decrypting with provided secret.\n" }
    before do
      data_bag "x", {}
      data_bag "canteloupe", {}
      data_bag "rocket", { "falcon9" => { heavy: "true" }, "atlas" => {}, "ariane" => {} }
      data_bag "encrypt", { "box" => { id: "box", foo: { "encrypted_data": "J8N0pJ+LFDQF3XvhzWgkSBOuZZn8Og==\n", "iv": "4S1sb4zLnMt71SXV\n", "auth_tag": "4ChINhxz4WmqOizvZNoPPg==\n", "version": 3, "cipher": "aes-256-gcm" } } }
    end

    context "with encrypted data" do
      context "provided secret key" do
        it "shows data if secret key is correct" do
          knife("data bag show encrypt box --secret #{right_secret}").should_succeed stderr: err, stdout: <<~EOM
            foo: bar
            id:  box
          EOM
        end

        it "raises error if secret key is incorrect" do
          expect { knife("data bag show encrypt box --secret #{wrong_secret}") }.to raise_error(Chef::EncryptedDataBagItem::DecryptionFailure)
        end
      end

      context "not provided secret key" do
        it "shows encrypted data with a warning" do
          expect(knife("data bag show encrypt box").stderr).to eq("WARNING: Encrypted data bag detected, but no secret provided for decoding. Displaying encrypted data.\n")
        end
      end
    end

    context "with unencrypted data" do
      context "provided secret key" do
        it "shows unencrypted data with a warning" do
          expect(knife("data bag show rocket falcon9 --secret #{right_secret}").stderr).to eq("WARNING: Unencrypted data bag detected, ignoring any provided secret options.\n")
        end
      end

      context "not provided secret key" do
        it "shows null with an empty data bag" do
          knife("data bag show canteloupe").should_succeed "\n"
        end

        it "show list of items in a bag" do
          knife("data bag show rocket").should_succeed <<~EOM
            ariane
            atlas
            falcon9
          EOM
        end

        it "show data of the item" do
          knife("data bag show rocket falcon9").should_succeed <<~EOM
            heavy: true
            id:    falcon9
          EOM
        end
      end
    end
  end
end