kanrisuru 0.12.1 → 0.13.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +4 -0
- data/lib/kanrisuru/version.rb +1 -1
- data/spec/functional/result_spec.rb +150 -0
- data/spec/{hosts.json → helper/hosts.json} +0 -0
- data/spec/helper/simplecov.rb +21 -0
- data/spec/helper/test_hosts.rb +1 -1
- data/spec/integration/core/apt/debian_spec.rb +9 -0
- data/spec/integration/core/apt/ubuntu_spec.rb +9 -0
- data/spec/integration/core/archive/centos_spec.rb +9 -0
- data/spec/integration/core/archive/debian_spec.rb +9 -0
- data/spec/integration/core/archive/fedora_spec.rb +9 -0
- data/spec/integration/core/archive/opensuse_spec.rb +9 -0
- data/spec/integration/core/archive/rhel_spec.rb +9 -0
- data/spec/integration/core/archive/sles_spec.rb +9 -0
- data/spec/integration/core/archive/ubuntu_spec.rb +9 -0
- data/spec/integration/core/disk/centos_spec.rb +9 -0
- data/spec/integration/core/disk/debian_spec.rb +9 -0
- data/spec/integration/core/disk/fedora_spec.rb +9 -0
- data/spec/integration/core/disk/opensuse_spec.rb +9 -0
- data/spec/integration/core/disk/rhel_spec.rb +9 -0
- data/spec/integration/core/disk/sles_spec.rb +9 -0
- data/spec/integration/core/disk/ubuntu_spec.rb +9 -0
- data/spec/integration/core/dmi/centos_spec.rb +9 -0
- data/spec/integration/core/dmi/debian_spec.rb +9 -0
- data/spec/integration/core/dmi/fedora_spec.rb +9 -0
- data/spec/integration/core/dmi/opensuse_spec.rb +9 -0
- data/spec/integration/core/dmi/rhel_spec.rb +9 -0
- data/spec/integration/core/dmi/sles_spec.rb +9 -0
- data/spec/integration/core/dmi/ubuntu_spec.rb +9 -0
- data/spec/integration/core/file/centos_spec.rb +9 -0
- data/spec/integration/core/file/debian_spec.rb +9 -0
- data/spec/integration/core/file/fedora_spec.rb +9 -0
- data/spec/integration/core/file/opensuse_spec.rb +9 -0
- data/spec/integration/core/file/rhel_spec.rb +9 -0
- data/spec/integration/core/file/sles_spec.rb +9 -0
- data/spec/integration/core/file/ubuntu_spec.rb +9 -0
- data/spec/integration/core/find/centos_spec.rb +9 -0
- data/spec/integration/core/find/debian_spec.rb +9 -0
- data/spec/integration/core/find/fedora_spec.rb +9 -0
- data/spec/integration/core/find/opensuse_spec.rb +9 -0
- data/spec/integration/core/find/rhel_spec.rb +9 -0
- data/spec/integration/core/find/sles_spec.rb +9 -0
- data/spec/integration/core/find/ubuntu_spec.rb +9 -0
- data/spec/integration/core/group/centos_spec.rb +9 -0
- data/spec/integration/core/group/debian_spec.rb +9 -0
- data/spec/integration/core/group/fedora_spec.rb +9 -0
- data/spec/integration/core/group/opensuse_spec.rb +9 -0
- data/spec/integration/core/group/rhel_spec.rb +9 -0
- data/spec/integration/core/group/sles_spec.rb +9 -0
- data/spec/integration/core/group/ubuntu_spec.rb +9 -0
- data/spec/integration/core/ip/centos_spec.rb +9 -0
- data/spec/integration/core/ip/debian_spec.rb +9 -0
- data/spec/integration/core/ip/fedora_spec.rb +9 -0
- data/spec/integration/core/ip/opensuse_spec.rb +9 -0
- data/spec/integration/core/ip/rhel_spec.rb +9 -0
- data/spec/integration/core/ip/sles_spec.rb +9 -0
- data/spec/integration/core/ip/ubuntu_spec.rb +9 -0
- data/spec/integration/core/path/centos_spec.rb +9 -0
- data/spec/integration/core/path/debian_spec.rb +9 -0
- data/spec/integration/core/path/fedora_spec.rb +9 -0
- data/spec/integration/core/path/opensuse_spec.rb +9 -0
- data/spec/integration/core/path/rhel_spec.rb +9 -0
- data/spec/integration/core/path/sles_spec.rb +9 -0
- data/spec/integration/core/path/ubuntu_spec.rb +9 -0
- data/spec/integration/core/socket/centos_spec.rb +9 -0
- data/spec/integration/core/socket/debian_spec.rb +9 -0
- data/spec/integration/core/socket/fedora_spec.rb +9 -0
- data/spec/integration/core/socket/opensuse_spec.rb +9 -0
- data/spec/integration/core/socket/rhel_spec.rb +9 -0
- data/spec/integration/core/socket/sles_spec.rb +9 -0
- data/spec/integration/core/socket/ubuntu_spec.rb +9 -0
- data/spec/integration/core/stat/centos_spec.rb +9 -0
- data/spec/integration/core/stat/debian_spec.rb +9 -0
- data/spec/integration/core/stat/fedora_spec.rb +9 -0
- data/spec/integration/core/stat/opensuse_spec.rb +9 -0
- data/spec/integration/core/stat/rhel_spec.rb +9 -0
- data/spec/integration/core/stat/sles_spec.rb +9 -0
- data/spec/integration/core/stat/ubuntu_spec.rb +9 -0
- data/spec/integration/core/stream/centos_spec.rb +9 -0
- data/spec/integration/core/stream/debian_spec.rb +9 -0
- data/spec/integration/core/stream/fedora_spec.rb +9 -0
- data/spec/integration/core/stream/opensuse_spec.rb +9 -0
- data/spec/integration/core/stream/rhel_spec.rb +9 -0
- data/spec/integration/core/stream/sles_spec.rb +9 -0
- data/spec/integration/core/stream/ubuntu_spec.rb +9 -0
- data/spec/integration/core/system/centos_spec.rb +9 -0
- data/spec/integration/core/system/debian_spec.rb +9 -0
- data/spec/integration/core/system/fedora_spec.rb +9 -0
- data/spec/integration/core/system/opensuse_spec.rb +9 -0
- data/spec/integration/core/system/rhel_spec.rb +9 -0
- data/spec/integration/core/system/sles_spec.rb +9 -0
- data/spec/integration/core/system/ubuntu_spec.rb +9 -0
- data/spec/integration/core/transfer/centos_spec.rb +9 -0
- data/spec/integration/core/transfer/debian_spec.rb +9 -0
- data/spec/integration/core/transfer/fedora_spec.rb +9 -0
- data/spec/integration/core/transfer/opensuse_spec.rb +9 -0
- data/spec/integration/core/transfer/rhel_spec.rb +9 -0
- data/spec/integration/core/transfer/sles_spec.rb +9 -0
- data/spec/integration/core/transfer/ubuntu_spec.rb +9 -0
- data/spec/integration/core/user/centos_spec.rb +9 -0
- data/spec/integration/core/user/debian_spec.rb +9 -0
- data/spec/integration/core/user/fedora_spec.rb +9 -0
- data/spec/integration/core/user/opensuse_spec.rb +9 -0
- data/spec/integration/core/user/rhel_spec.rb +9 -0
- data/spec/integration/core/user/sles_spec.rb +9 -0
- data/spec/integration/core/user/ubuntu_spec.rb +9 -0
- data/spec/integration/core/yum/centos_spec.rb +9 -0
- data/spec/integration/core/yum/fedora_spec.rb +9 -0
- data/spec/integration/core/yum/rhel_spec.rb +9 -0
- data/spec/integration/core/zypper/opensuse_spec.rb +9 -0
- data/spec/integration/core/zypper/sles_spec.rb +9 -0
- data/spec/integration/remote/cluster/ubuntu_spec.rb +9 -0
- data/spec/integration/remote/cpu/centos_spec.rb +9 -0
- data/spec/integration/remote/cpu/debian_spec.rb +9 -0
- data/spec/integration/remote/cpu/fedora_spec.rb +9 -0
- data/spec/integration/remote/cpu/opensuse_spec.rb +9 -0
- data/spec/integration/remote/cpu/rhel_spec.rb +9 -0
- data/spec/integration/remote/cpu/sles_spec.rb +9 -0
- data/spec/integration/remote/cpu/ubuntu_spec.rb +9 -0
- data/spec/integration/remote/env/centos_spec.rb +9 -0
- data/spec/integration/remote/env/debian_spec.rb +9 -0
- data/spec/integration/remote/env/fedora_spec.rb +9 -0
- data/spec/integration/remote/env/opensuse_spec.rb +9 -0
- data/spec/integration/remote/env/rhel_spec.rb +9 -0
- data/spec/integration/remote/env/sles_spec.rb +9 -0
- data/spec/integration/remote/env/ubuntu_spec.rb +9 -0
- data/spec/integration/remote/fstab/centos_spec.rb +9 -0
- data/spec/integration/remote/fstab/debian_spec.rb +9 -0
- data/spec/integration/remote/fstab/fedora_spec.rb +9 -0
- data/spec/integration/remote/fstab/opensuse_spec.rb +9 -0
- data/spec/integration/remote/fstab/rhel_spec.rb +9 -0
- data/spec/integration/remote/fstab/sles_spec.rb +9 -0
- data/spec/integration/remote/fstab/ubuntu_spec.rb +9 -0
- data/spec/integration/remote/host/centos_spec.rb +9 -0
- data/spec/integration/remote/host/debian_spec.rb +9 -0
- data/spec/integration/remote/host/fedora_spec.rb +9 -0
- data/spec/integration/remote/host/opensuse_spec.rb +9 -0
- data/spec/integration/remote/host/rhel_spec.rb +9 -0
- data/spec/integration/remote/host/sles_spec.rb +9 -0
- data/spec/integration/remote/host/ubuntu_spec.rb +9 -0
- data/spec/integration/remote/memory/centos_spec.rb +9 -0
- data/spec/integration/remote/memory/debian_spec.rb +9 -0
- data/spec/integration/remote/memory/fedora_spec.rb +9 -0
- data/spec/integration/remote/memory/opensuse_spec.rb +9 -0
- data/spec/integration/remote/memory/rhel_spec.rb +9 -0
- data/spec/integration/remote/memory/sles_spec.rb +9 -0
- data/spec/integration/remote/memory/ubuntu_spec.rb +9 -0
- data/spec/integration/remote/os/centos_spec.rb +9 -0
- data/spec/integration/remote/os/debian_spec.rb +9 -0
- data/spec/integration/remote/os/fedora_spec.rb +9 -0
- data/spec/integration/remote/os/opensuse_spec.rb +9 -0
- data/spec/integration/remote/os/rhel_spec.rb +9 -0
- data/spec/integration/remote/os/sles_spec.rb +9 -0
- data/spec/integration/remote/os/ubuntu_spec.rb +9 -0
- data/spec/integration/remote/remote_file/centos_spec.rb +9 -0
- data/spec/integration/remote/remote_file/debian_spec.rb +9 -0
- data/spec/integration/remote/remote_file/fedora_spec.rb +9 -0
- data/spec/integration/remote/remote_file/opensuse_spec.rb +9 -0
- data/spec/integration/remote/remote_file/rhel_spec.rb +9 -0
- data/spec/integration/remote/remote_file/sles_spec.rb +9 -0
- data/spec/integration/remote/remote_file/ubuntu_spec.rb +9 -0
- data/spec/spec_helper.rb +2 -11
- data/spec/support/shared_examples/integration/core/apt.rb +117 -0
- data/spec/support/shared_examples/integration/core/archive.rb +221 -0
- data/spec/support/shared_examples/integration/core/disk.rb +91 -0
- data/spec/support/shared_examples/integration/core/dmi.rb +34 -0
- data/spec/support/shared_examples/integration/core/file.rb +357 -0
- data/spec/support/shared_examples/integration/core/find.rb +50 -0
- data/spec/support/shared_examples/integration/core/group.rb +62 -0
- data/spec/support/shared_examples/integration/core/ip.rb +68 -0
- data/spec/support/shared_examples/integration/core/path.rb +90 -0
- data/spec/support/shared_examples/integration/core/socket.rb +27 -0
- data/spec/support/shared_examples/integration/core/stat.rb +95 -0
- data/spec/support/shared_examples/integration/core/stream.rb +112 -0
- data/spec/support/shared_examples/integration/core/system.rb +155 -0
- data/spec/support/shared_examples/integration/core/transfer.rb +101 -0
- data/spec/support/shared_examples/integration/core/user.rb +72 -0
- data/spec/support/shared_examples/integration/core/yum.rb +115 -0
- data/spec/support/shared_examples/integration/core/zypper.rb +196 -0
- data/spec/{integration/remote/cluster_spec.rb → support/shared_examples/integration/remote/cluster.rb} +2 -2
- data/spec/support/shared_examples/integration/remote/cpu.rb +38 -0
- data/spec/support/shared_examples/integration/remote/env_spec.rb +33 -0
- data/spec/support/shared_examples/integration/remote/fstab.rb +89 -0
- data/spec/support/shared_examples/integration/remote/host.rb +65 -0
- data/spec/support/shared_examples/integration/remote/memory.rb +27 -0
- data/spec/support/shared_examples/integration/remote/os.rb +60 -0
- data/spec/support/shared_examples/integration/remote/remote_file.rb +172 -0
- metadata +185 -29
- data/spec/integration/core/apt_spec.rb +0 -119
- data/spec/integration/core/archive_spec.rb +0 -223
- data/spec/integration/core/disk_spec.rb +0 -93
- data/spec/integration/core/dmi_spec.rb +0 -36
- data/spec/integration/core/file_spec.rb +0 -359
- data/spec/integration/core/find_spec.rb +0 -52
- data/spec/integration/core/group_spec.rb +0 -64
- data/spec/integration/core/ip_spec.rb +0 -70
- data/spec/integration/core/path_spec.rb +0 -92
- data/spec/integration/core/socket_spec.rb +0 -29
- data/spec/integration/core/stat_spec.rb +0 -97
- data/spec/integration/core/stream_spec.rb +0 -114
- data/spec/integration/core/system_spec.rb +0 -142
- data/spec/integration/core/transfer_spec.rb +0 -103
- data/spec/integration/core/user_spec.rb +0 -74
- data/spec/integration/core/yum_spec.rb +0 -117
- data/spec/integration/core/zypper_spec.rb +0 -198
- data/spec/integration/remote/cpu_spec.rb +0 -40
- data/spec/integration/remote/env_spec.rb +0 -35
- data/spec/integration/remote/fstab_spec.rb +0 -91
- data/spec/integration/remote/host_spec.rb +0 -67
- data/spec/integration/remote/memory_spec.rb +0 -29
- data/spec/integration/remote/os_spec.rb +0 -62
- data/spec/integration/remote/remote_file_spec.rb +0 -174
- data/spec/zz_reboot_spec.rb +0 -46
@@ -1,198 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'spec_helper'
|
4
|
-
|
5
|
-
TestHosts.each_os(only: %w[sles opensuse]) do |os_name, host_json|
|
6
|
-
RSpec.describe Kanrisuru::Core::Zypper do
|
7
|
-
context "with #{os_name}" do
|
8
|
-
let(:host) do
|
9
|
-
Kanrisuru::Remote::Host.new(
|
10
|
-
host: host_json['hostname'],
|
11
|
-
username: host_json['username'],
|
12
|
-
keys: [host_json['ssh_key']]
|
13
|
-
)
|
14
|
-
end
|
15
|
-
|
16
|
-
after do
|
17
|
-
host.disconnect
|
18
|
-
end
|
19
|
-
|
20
|
-
def find_repo(host, repo_name)
|
21
|
-
repos = host.zypper('repos').data
|
22
|
-
repos.find { |repo| repo.alias == repo_name }
|
23
|
-
end
|
24
|
-
|
25
|
-
it 'lists repos' do
|
26
|
-
result = host.zypper('repos')
|
27
|
-
expect(result).to be_success
|
28
|
-
end
|
29
|
-
|
30
|
-
it 'installs a package' do
|
31
|
-
host.su('root')
|
32
|
-
result = host.zypper('install', packages: 'nginx')
|
33
|
-
expect(result).to be_success
|
34
|
-
end
|
35
|
-
|
36
|
-
it 'installs multiple packages' do
|
37
|
-
host.su('root')
|
38
|
-
result = host.zypper('install', packages: %w[curl nginx])
|
39
|
-
expect(result).to be_success
|
40
|
-
end
|
41
|
-
|
42
|
-
it 'removes a package' do
|
43
|
-
host.su('root')
|
44
|
-
result = host.zypper('remove', packages: ['nginx'])
|
45
|
-
expect(result).to be_success
|
46
|
-
end
|
47
|
-
|
48
|
-
it 'lists updates' do
|
49
|
-
result = host.zypper('list-updates')
|
50
|
-
expect(result).to be_success
|
51
|
-
end
|
52
|
-
|
53
|
-
it 'lists patches' do
|
54
|
-
result = host.zypper('list-patches')
|
55
|
-
expect(result).to be_success
|
56
|
-
end
|
57
|
-
|
58
|
-
it 'lists important and secure patches' do
|
59
|
-
result = host.zypper('list-patches', category: ['security'], severity: %w[important moderate])
|
60
|
-
expect(result).to be_success
|
61
|
-
end
|
62
|
-
|
63
|
-
it 'lists patch check counts' do
|
64
|
-
result = host.zypper('patch-check')
|
65
|
-
expect(result).to be_success
|
66
|
-
end
|
67
|
-
|
68
|
-
it 'updates a package' do
|
69
|
-
host.su('root')
|
70
|
-
result = host.zypper('update', packages: 'curl')
|
71
|
-
expect(result).to be_success
|
72
|
-
end
|
73
|
-
|
74
|
-
it 'gets info for one package' do
|
75
|
-
result = host.zypper('info', packages: 'curl')
|
76
|
-
expect(result).to be_success
|
77
|
-
end
|
78
|
-
|
79
|
-
it 'gets info for multiple packages' do
|
80
|
-
result = host.zypper('info', packages: %w[curl wget git sudo])
|
81
|
-
expect(result).to be_success
|
82
|
-
end
|
83
|
-
|
84
|
-
it 'gets info for type' do
|
85
|
-
result = host.zypper('info', type: 'package', packages: 'gc*')
|
86
|
-
expect(result).to be_success
|
87
|
-
end
|
88
|
-
|
89
|
-
it 'patches system' do
|
90
|
-
host.su('root')
|
91
|
-
result = host.zypper('patch', severity: 'moderate')
|
92
|
-
expect(result).to be_success
|
93
|
-
end
|
94
|
-
|
95
|
-
it 'performs a dist-upgrade' do
|
96
|
-
case os_name
|
97
|
-
when 'opensuse'
|
98
|
-
host.su('root')
|
99
|
-
result = host.zypper('dist-upgrade', dry_run: true)
|
100
|
-
expect(result).to be_success
|
101
|
-
when 'sles'
|
102
|
-
host.su('root')
|
103
|
-
result = host.zypper('dist-upgrade', dry_run: true, auto_agree_with_licenses: true)
|
104
|
-
expect(result).to be_success
|
105
|
-
end
|
106
|
-
end
|
107
|
-
|
108
|
-
it 'searches for single package with match' do
|
109
|
-
result = host.zypper('search', packages: 'gc*', sort_by_name: true)
|
110
|
-
expect(result).to be_success
|
111
|
-
end
|
112
|
-
|
113
|
-
it 'searches for multiple packages' do
|
114
|
-
result = host.zypper('search', packages: %w[nginx ffmpeg], sort_by_repo: true)
|
115
|
-
expect(result).to be_success
|
116
|
-
end
|
117
|
-
|
118
|
-
it 'manages a repo' do
|
119
|
-
repo_alias = 'graphics'
|
120
|
-
if os_name == 'opensuse'
|
121
|
-
repo_name = 'Graphics Project (openSUSE_Leap_15.2)'
|
122
|
-
repo_uri = 'https://download.opensuse.org/repositories/graphics/openSUSE_Leap_15.2/'
|
123
|
-
else
|
124
|
-
repo_name = 'Graphics Project (openSUSE_Leap_15.3)'
|
125
|
-
repo_uri = 'https://download.opensuse.org/repositories/graphics/openSUSE_Leap_15.3/'
|
126
|
-
end
|
127
|
-
|
128
|
-
url = "#{repo_uri}/#{repo_alias}.repo"
|
129
|
-
|
130
|
-
host.su('root')
|
131
|
-
result = host.zypper('addrepo', repos: url)
|
132
|
-
expect(result).to be_success
|
133
|
-
|
134
|
-
repo = find_repo(host, repo_alias)
|
135
|
-
|
136
|
-
expect(repo).to be_instance_of(Kanrisuru::Core::Zypper::Repo)
|
137
|
-
expect(repo.uri).to eq(repo_uri)
|
138
|
-
expect(repo.name).to eq(repo_name)
|
139
|
-
|
140
|
-
new_repo_alias = 'graphics-repo'
|
141
|
-
result = host.zypper('renamerepo', repo: repo_alias, alias: new_repo_alias)
|
142
|
-
expect(result).to be_success
|
143
|
-
repo = find_repo(host, new_repo_alias)
|
144
|
-
expect(repo.alias).to eq(new_repo_alias)
|
145
|
-
|
146
|
-
result = host.zypper('modifyrepo', repos: new_repo_alias, disable: true)
|
147
|
-
expect(result).to be_success
|
148
|
-
repo = find_repo(host, new_repo_alias)
|
149
|
-
expect(repo.enabled).to be_falsey
|
150
|
-
|
151
|
-
result = host.zypper('removerepo', repos: new_repo_alias)
|
152
|
-
expect(result).to be_success
|
153
|
-
|
154
|
-
repo = find_repo(host, new_repo_alias)
|
155
|
-
expect(repo).to be_nil
|
156
|
-
end
|
157
|
-
|
158
|
-
it 'refreshes repos' do
|
159
|
-
host.su('root')
|
160
|
-
result = host.zypper('refresh')
|
161
|
-
expect(result).to be_success
|
162
|
-
end
|
163
|
-
|
164
|
-
it 'cleans repo caches' do
|
165
|
-
host.su('root')
|
166
|
-
result = host.zypper('clean')
|
167
|
-
expect(result).to be_success
|
168
|
-
end
|
169
|
-
|
170
|
-
it 'lists services' do
|
171
|
-
result = host.zypper('services')
|
172
|
-
expect(result).to be_success
|
173
|
-
end
|
174
|
-
|
175
|
-
it 'refreshes services' do
|
176
|
-
host.su('root')
|
177
|
-
result = host.zypper('refresh-services')
|
178
|
-
expect(result).to be_success
|
179
|
-
end
|
180
|
-
|
181
|
-
it 'manages locks' do
|
182
|
-
host.su('root')
|
183
|
-
result = host.zypper('addlock', lock: 'nginx', type: 'package')
|
184
|
-
expect(result).to be_success
|
185
|
-
|
186
|
-
result = host.zypper('locks')
|
187
|
-
expect(result).to be_success
|
188
|
-
|
189
|
-
lock = result.first
|
190
|
-
expect(lock.name).to eq('nginx')
|
191
|
-
expect(lock.type).to eq('package')
|
192
|
-
|
193
|
-
result = host.zypper('removelock', lock: 'nginx')
|
194
|
-
expect(result).to be_success
|
195
|
-
end
|
196
|
-
end
|
197
|
-
end
|
198
|
-
end
|
@@ -1,40 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'spec_helper'
|
4
|
-
|
5
|
-
TestHosts.each_os do |os_name, host_json|
|
6
|
-
RSpec.describe Kanrisuru::Remote::Cpu do
|
7
|
-
context "with #{os_name}" do
|
8
|
-
let(:host) do
|
9
|
-
Kanrisuru::Remote::Host.new(
|
10
|
-
host: host_json['hostname'],
|
11
|
-
username: host_json['username'],
|
12
|
-
keys: [host_json['ssh_key']]
|
13
|
-
)
|
14
|
-
end
|
15
|
-
|
16
|
-
after do
|
17
|
-
host.disconnect
|
18
|
-
end
|
19
|
-
|
20
|
-
it 'gets cpu details' do
|
21
|
-
expect(host.cpu.cores).to eq(1)
|
22
|
-
expect(host.cpu.total).to eq(1)
|
23
|
-
expect(host.cpu.count).to eq(1)
|
24
|
-
|
25
|
-
expect(host.cpu.threads_per_core).to eq(1)
|
26
|
-
expect(host.cpu.cores_per_socket).to eq(1)
|
27
|
-
expect(host.cpu.sockets).to eq(1)
|
28
|
-
|
29
|
-
expect(host.cpu.hyperthreading?).to eq(false)
|
30
|
-
end
|
31
|
-
|
32
|
-
it 'gets cpu load average' do
|
33
|
-
expect(host.cpu.load_average).to be_instance_of(Array)
|
34
|
-
expect(host.cpu.load_average1).to be_instance_of(Float)
|
35
|
-
expect(host.cpu.load_average5).to be_instance_of(Float)
|
36
|
-
expect(host.cpu.load_average15).to be_instance_of(Float)
|
37
|
-
end
|
38
|
-
end
|
39
|
-
end
|
40
|
-
end
|
@@ -1,35 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'spec_helper'
|
4
|
-
|
5
|
-
TestHosts.each_os do |os_name, host_json|
|
6
|
-
RSpec.describe Kanrisuru::Remote::Env do
|
7
|
-
context "with #{os_name}" do
|
8
|
-
let(:host) do
|
9
|
-
Kanrisuru::Remote::Host.new(
|
10
|
-
host: host_json['hostname'],
|
11
|
-
username: host_json['username'],
|
12
|
-
keys: [host_json['ssh_key']]
|
13
|
-
)
|
14
|
-
end
|
15
|
-
|
16
|
-
after do
|
17
|
-
host.disconnect
|
18
|
-
end
|
19
|
-
|
20
|
-
it 'sets env var' do
|
21
|
-
host.env['HELLO'] = 'world'
|
22
|
-
host.env['KANRISURU'] = 'manage'
|
23
|
-
|
24
|
-
expect(host.env['KANRISURU']).to eq('manage')
|
25
|
-
expect(host.env.to_s).to eq('export HELLO=world; export KANRISURU=manage;')
|
26
|
-
expect(host.env.to_h).to eq({ 'HELLO' => 'world', 'KANRISURU' => 'manage' })
|
27
|
-
|
28
|
-
command = Kanrisuru::Command.new('echo $KANRISURU $HELLO')
|
29
|
-
host.execute_shell(command)
|
30
|
-
|
31
|
-
expect(command.to_s).to eq('manage world')
|
32
|
-
end
|
33
|
-
end
|
34
|
-
end
|
35
|
-
end
|
@@ -1,91 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
TestHosts.each_os do |os_name, host_json|
|
4
|
-
RSpec.describe Kanrisuru::Remote::Fstab do
|
5
|
-
context "with #{os_name}" do
|
6
|
-
let(:host) do
|
7
|
-
Kanrisuru::Remote::Host.new(
|
8
|
-
host: host_json['hostname'],
|
9
|
-
username: host_json['username'],
|
10
|
-
keys: [host_json['ssh_key']]
|
11
|
-
)
|
12
|
-
end
|
13
|
-
|
14
|
-
after do
|
15
|
-
host.disconnect
|
16
|
-
end
|
17
|
-
|
18
|
-
it 'outputs string version of fstab' do
|
19
|
-
host.su('root')
|
20
|
-
|
21
|
-
result = host.cat('/etc/fstab')
|
22
|
-
expect(result).to be_success
|
23
|
-
raw_file_lines = []
|
24
|
-
result.each do |line|
|
25
|
-
next if line.match(/^#/) || line == ''
|
26
|
-
|
27
|
-
raw_file_lines << line.split.join(' ')
|
28
|
-
end
|
29
|
-
|
30
|
-
raw_file_output = raw_file_lines.join("\n")
|
31
|
-
expect(raw_file_output).to eq(host.fstab.to_s)
|
32
|
-
end
|
33
|
-
|
34
|
-
it 'parses fstab' do
|
35
|
-
host.su('root')
|
36
|
-
fstab = host.fstab
|
37
|
-
|
38
|
-
entry =
|
39
|
-
case os_name
|
40
|
-
when 'opensuse'
|
41
|
-
fstab['/dev/vda3']
|
42
|
-
when 'sles'
|
43
|
-
fstab['/dev/xvda1']
|
44
|
-
else
|
45
|
-
fstab['/dev/vda1']
|
46
|
-
end
|
47
|
-
|
48
|
-
expect(fstab.get_entry(entry.uuid)).to eq(entry)
|
49
|
-
expect(fstab.get_entry(entry.label)).to eq(entry)
|
50
|
-
|
51
|
-
fstab << Kanrisuru::Remote::Fstab::Entry.new(
|
52
|
-
device: '/dev/vda14',
|
53
|
-
mount_point: '/mnt/test',
|
54
|
-
type: 'ext4',
|
55
|
-
opts: { defaults: true },
|
56
|
-
freq: '0',
|
57
|
-
passno: '0'
|
58
|
-
)
|
59
|
-
|
60
|
-
entry = fstab['/dev/vda14']
|
61
|
-
expect(entry.to_s).to eq('/dev/vda14 /mnt/test ext4 defaults 0 0')
|
62
|
-
expect(entry.device).to eq('/dev/vda14')
|
63
|
-
expect(entry.mount_point).to eq('/mnt/test')
|
64
|
-
expect(entry.type).to eq('ext4')
|
65
|
-
expect(entry.opts.to_s).to eq('defaults')
|
66
|
-
expect(entry.freq).to eq('0')
|
67
|
-
expect(entry.passno).to eq('0')
|
68
|
-
|
69
|
-
entry.opts['defaults'] = false
|
70
|
-
entry.opts['user'] = true
|
71
|
-
entry.opts['exec'] = true
|
72
|
-
entry.opts['rw'] = true
|
73
|
-
entry.opts['auto'] = true
|
74
|
-
entry.opts['relatime'] = true
|
75
|
-
entry.opts['async'] = true
|
76
|
-
entry.opts[:nodev] = true
|
77
|
-
entry.opts[:nosuid] = true
|
78
|
-
entry.opts[:owner] = true
|
79
|
-
entry.opts[:group] = true
|
80
|
-
|
81
|
-
entry.mount_point = '/mnt/test3'
|
82
|
-
|
83
|
-
expect(fstab['/dev/vda14'].to_s).to eq '/dev/vda14 /mnt/test3 ext4 ' \
|
84
|
-
'user,exec,rw,auto,relatime,async,nodev,nosuid,owner,group 0 0'
|
85
|
-
|
86
|
-
fstab << '/dev/vda16 /mnt/test2 fat defaults,user,uid=1000,gid=1000 0 0'
|
87
|
-
expect(fstab['/dev/vda16'].to_s).to eq('/dev/vda16 /mnt/test2 fat defaults,user,uid=1000,gid=1000 0 0')
|
88
|
-
end
|
89
|
-
end
|
90
|
-
end
|
91
|
-
end
|
@@ -1,67 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'spec_helper'
|
4
|
-
|
5
|
-
TestHosts.each_os do |os_name, host_json|
|
6
|
-
RSpec.describe Kanrisuru::Remote::Host do
|
7
|
-
context "with #{os_name}" do
|
8
|
-
let(:host) do
|
9
|
-
described_class.new(
|
10
|
-
host: host_json['hostname'],
|
11
|
-
username: host_json['username'],
|
12
|
-
keys: [host_json['ssh_key']]
|
13
|
-
)
|
14
|
-
end
|
15
|
-
|
16
|
-
after do
|
17
|
-
host.disconnect
|
18
|
-
end
|
19
|
-
|
20
|
-
it 'can ping localhost' do
|
21
|
-
expect(host.ping?).to eq(true)
|
22
|
-
end
|
23
|
-
|
24
|
-
it 'gets hostname' do
|
25
|
-
expect(host.hostname).to eq(host_json['hostname'])
|
26
|
-
end
|
27
|
-
|
28
|
-
it 'changes directories' do
|
29
|
-
expect(host.pwd.path).to eq(host_json['home'])
|
30
|
-
|
31
|
-
host.cd('../')
|
32
|
-
expect(host.pwd.path).to eq('/home')
|
33
|
-
|
34
|
-
host.cd('../')
|
35
|
-
expect(host.pwd.path).to eq('/')
|
36
|
-
|
37
|
-
host.cd('~')
|
38
|
-
|
39
|
-
expect(host.pwd.path).to eq(host_json['home'])
|
40
|
-
|
41
|
-
host.su('root')
|
42
|
-
host.cd('/root/../etc')
|
43
|
-
|
44
|
-
result = host.ls
|
45
|
-
paths = result.map(&:path)
|
46
|
-
|
47
|
-
expect(paths).to include('hosts')
|
48
|
-
expect(paths).to include('shadow')
|
49
|
-
expect(paths).to include('ssh')
|
50
|
-
|
51
|
-
host.cd('default')
|
52
|
-
expect(host.pwd.path).to eq('/etc/default')
|
53
|
-
|
54
|
-
host.su(host_json['username'])
|
55
|
-
|
56
|
-
host.cd('.')
|
57
|
-
expect(host.pwd.path).to eq('/etc/default')
|
58
|
-
|
59
|
-
result = host.ls(path: '/home')
|
60
|
-
expect(result[0].path).to eq(host_json['username'])
|
61
|
-
|
62
|
-
host.cd('/bin')
|
63
|
-
expect(host.pwd.path).to eq('/bin')
|
64
|
-
end
|
65
|
-
end
|
66
|
-
end
|
67
|
-
end
|
@@ -1,29 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'spec_helper'
|
4
|
-
|
5
|
-
TestHosts.each_os do |os_name|
|
6
|
-
RSpec.describe Kanrisuru::Remote::Memory do
|
7
|
-
context "with #{os_name}" do
|
8
|
-
let(:host_json) { TestHosts.host(os_name) }
|
9
|
-
let(:host) do
|
10
|
-
Kanrisuru::Remote::Host.new(
|
11
|
-
host: host_json['hostname'],
|
12
|
-
username: host_json['username'],
|
13
|
-
keys: [host_json['ssh_key']]
|
14
|
-
)
|
15
|
-
end
|
16
|
-
|
17
|
-
after do
|
18
|
-
host.disconnect
|
19
|
-
end
|
20
|
-
|
21
|
-
it 'gets memory details' do
|
22
|
-
expect(host.memory.total(:gb)).to be >= 0.5
|
23
|
-
expect(host.memory.free(:mb)).to be >= 10.0
|
24
|
-
expect(host.memory.swap).to be_instance_of(Integer)
|
25
|
-
expect(host.memory.swap_free).to be_instance_of(Integer)
|
26
|
-
end
|
27
|
-
end
|
28
|
-
end
|
29
|
-
end
|
@@ -1,62 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require 'spec_helper'
|
4
|
-
|
5
|
-
TestHosts.each_os do |os_name, host_json|
|
6
|
-
RSpec.describe Kanrisuru::Remote::Os do
|
7
|
-
context "with #{os_name}" do
|
8
|
-
let(:host) do
|
9
|
-
Kanrisuru::Remote::Host.new(
|
10
|
-
host: host_json['hostname'],
|
11
|
-
username: host_json['username'],
|
12
|
-
keys: [host_json['ssh_key']]
|
13
|
-
)
|
14
|
-
end
|
15
|
-
|
16
|
-
after do
|
17
|
-
host.disconnect
|
18
|
-
end
|
19
|
-
|
20
|
-
it 'detects os specs' do
|
21
|
-
expect(host.os.kernel).to eq(host_json['kernel'])
|
22
|
-
expect(host.os.processor).to eq('x86_64')
|
23
|
-
|
24
|
-
case os_name
|
25
|
-
when 'opensuse'
|
26
|
-
expect(host.os.release).to eq('opensuse_leap')
|
27
|
-
else
|
28
|
-
expect(host.os.release).to eq(os_name)
|
29
|
-
end
|
30
|
-
|
31
|
-
expect(host.os.version).to be > 0.00
|
32
|
-
|
33
|
-
case os_name
|
34
|
-
when 'debian'
|
35
|
-
expect(host.os.version).to eq(10)
|
36
|
-
when 'ubuntu'
|
37
|
-
expect(host.os.version).to eq(18.04)
|
38
|
-
when 'fedora'
|
39
|
-
expect(host.os.version).to eq(32)
|
40
|
-
when 'centos'
|
41
|
-
expect(host.os.version).to eq(7)
|
42
|
-
when 'opensuse'
|
43
|
-
expect(host.os.version).to eq(15.2)
|
44
|
-
when 'rhel'
|
45
|
-
expect(host.os.version).to eq(7.9)
|
46
|
-
end
|
47
|
-
end
|
48
|
-
|
49
|
-
it 'gets uname' do
|
50
|
-
expect(host.os.uname).to eq(host_json['kernel'])
|
51
|
-
end
|
52
|
-
|
53
|
-
it 'gets uname details' do
|
54
|
-
host.os.uname(
|
55
|
-
kernel_name: true,
|
56
|
-
hardware_platform: true,
|
57
|
-
operating_system: true
|
58
|
-
)
|
59
|
-
end
|
60
|
-
end
|
61
|
-
end
|
62
|
-
end
|
@@ -1,174 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
module Kanrisuru
|
4
|
-
module Remote
|
5
|
-
Class.new(File) do
|
6
|
-
READ_FILE_SIZE = 25_000
|
7
|
-
end
|
8
|
-
end
|
9
|
-
end
|
10
|
-
|
11
|
-
TestHosts.each_os do |os_name, host_json, spec_dir|
|
12
|
-
RSpec.describe Kanrisuru::Remote::File do
|
13
|
-
context "with #{os_name}" do
|
14
|
-
before(:all) do
|
15
|
-
host = Kanrisuru::Remote::Host.new(
|
16
|
-
host: host_json['hostname'],
|
17
|
-
username: host_json['username'],
|
18
|
-
keys: [host_json['ssh_key']]
|
19
|
-
)
|
20
|
-
|
21
|
-
host.mkdir(spec_dir, silent: true)
|
22
|
-
host.disconnect
|
23
|
-
end
|
24
|
-
|
25
|
-
let(:host) do
|
26
|
-
Kanrisuru::Remote::Host.new(
|
27
|
-
host: host_json['hostname'],
|
28
|
-
username: host_json['username'],
|
29
|
-
keys: [host_json['ssh_key']]
|
30
|
-
)
|
31
|
-
end
|
32
|
-
|
33
|
-
after do
|
34
|
-
host.disconnect
|
35
|
-
end
|
36
|
-
|
37
|
-
after(:all) do
|
38
|
-
host = Kanrisuru::Remote::Host.new(
|
39
|
-
host: host_json['hostname'],
|
40
|
-
username: host_json['username'],
|
41
|
-
keys: [host_json['ssh_key']]
|
42
|
-
)
|
43
|
-
|
44
|
-
host.rmdir(spec_dir)
|
45
|
-
host.disconnect
|
46
|
-
end
|
47
|
-
|
48
|
-
it 'loads a remote file to edit' do
|
49
|
-
file = host.file("#{spec_dir}/remote-file.txt")
|
50
|
-
|
51
|
-
expect(file).to be_instance_of(described_class)
|
52
|
-
expect(file.exists?).to eq(false)
|
53
|
-
expect(file.expand_path).to eq('')
|
54
|
-
|
55
|
-
file.touch
|
56
|
-
|
57
|
-
expect(file.exists?).to eq(true)
|
58
|
-
expect(file.zero?).to eq(true)
|
59
|
-
expect(file.user).to eq(host_json['username'])
|
60
|
-
|
61
|
-
case os_name
|
62
|
-
when 'opensuse', 'sles'
|
63
|
-
expect(file.group).to eq('users')
|
64
|
-
else
|
65
|
-
expect(file.group).to eq(host_json['username'])
|
66
|
-
end
|
67
|
-
|
68
|
-
expect(file.expand_path).to eq("#{spec_dir}/remote-file.txt")
|
69
|
-
|
70
|
-
file.append do |f|
|
71
|
-
f << 'Hello world'
|
72
|
-
f << 'this is a test!'
|
73
|
-
end
|
74
|
-
|
75
|
-
lines = file.map { |line| line }
|
76
|
-
expect(lines).to eq(['Hello world', 'this is a test!'])
|
77
|
-
expect(file.zero?).to eq(false)
|
78
|
-
|
79
|
-
file.prepend do |f|
|
80
|
-
f << 'Lines exist'
|
81
|
-
f << 'at the beginning...'
|
82
|
-
end
|
83
|
-
|
84
|
-
expect(file[0]).to eq('Lines exist')
|
85
|
-
expect(file[3]).to eq('this is a test!')
|
86
|
-
|
87
|
-
lines = file.map { |line| line }
|
88
|
-
expect(lines).to eq(['Lines exist', 'at the beginning...', 'Hello world', 'this is a test!'])
|
89
|
-
|
90
|
-
expect(file.delete).to eq(true)
|
91
|
-
expect(file.exists?).to eq(false)
|
92
|
-
end
|
93
|
-
|
94
|
-
it 'finds and updates file' do
|
95
|
-
file = host.file("#{spec_dir}/hosts.conf.test")
|
96
|
-
|
97
|
-
file.touch
|
98
|
-
|
99
|
-
file.write do |f|
|
100
|
-
f << '127.0.0.1 localhost'
|
101
|
-
f << '127.0.1.1 ubuntu'
|
102
|
-
f << ''
|
103
|
-
f << '# The following lines are desirable for IPv6 capable hosts'
|
104
|
-
f << '::1 ip6-localhost ip6-loopback'
|
105
|
-
f << 'fe00::0 ip6-localnet'
|
106
|
-
f << 'ff00::0 ip6-mcastprefix'
|
107
|
-
f << 'ff02::1 ip6-allnodes'
|
108
|
-
f << 'ff02::2 ip6-allrouters'
|
109
|
-
f << 'ff02::3 ip6-allhosts'
|
110
|
-
end
|
111
|
-
|
112
|
-
expect(file[2]).to eq('')
|
113
|
-
file.find_and_append(/^127.0.1.1 ubuntu/, '8.8.8.8 rickroll.com')
|
114
|
-
expect(file[2]).to eq('8.8.8.8 rickroll.com')
|
115
|
-
|
116
|
-
expect(file[1]).to eq('127.0.1.1 ubuntu')
|
117
|
-
file.find_and_prepend(/^127.0.1.1 ubuntu/, '1.1.1.1 nevergoingtoletyoudown.io')
|
118
|
-
expect(file[1]).to eq('1.1.1.1 nevergoingtoletyoudown.io')
|
119
|
-
|
120
|
-
file.prepend do |f|
|
121
|
-
f << '# Generated by Kanrisuru'
|
122
|
-
end
|
123
|
-
|
124
|
-
file.find_and_replace_line(/#/, '# Rick Astley was here')
|
125
|
-
expect(file[0]).to eq('# Rick Astley was here')
|
126
|
-
expect(file[6]).to eq('# Rick Astley was here')
|
127
|
-
|
128
|
-
file.find_and_replace_value(/\slocalhost/, ' nevergoingtogiveyouup.biz')
|
129
|
-
expect(file[1]).to eq('127.0.0.1 nevergoingtogiveyouup.biz')
|
130
|
-
|
131
|
-
file.find_and_remove(/^::/)
|
132
|
-
file.find_and_remove(/^ff/)
|
133
|
-
file.find_and_remove(/^fe/)
|
134
|
-
|
135
|
-
expect(file.lines).to eq(7)
|
136
|
-
end
|
137
|
-
|
138
|
-
it 'iterates with chunking' do
|
139
|
-
file = host.file("#{spec_dir}/remote-file-large.txt")
|
140
|
-
|
141
|
-
expect(file.exists?).to eq(false)
|
142
|
-
|
143
|
-
file.touch
|
144
|
-
|
145
|
-
file.write do |f|
|
146
|
-
(0...50_000).each do |i|
|
147
|
-
f << "Line: #{i}"
|
148
|
-
end
|
149
|
-
end
|
150
|
-
|
151
|
-
line = file.find do |f|
|
152
|
-
f == 'Line: 1111'
|
153
|
-
end
|
154
|
-
|
155
|
-
expect(line).to eq('Line: 1111')
|
156
|
-
|
157
|
-
expect(file[0]).to eq('Line: 0')
|
158
|
-
expect(file[5]).to eq('Line: 5')
|
159
|
-
expect(file[28_445]).to eq('Line: 28445')
|
160
|
-
expect(file[49_999]).to eq('Line: 49999')
|
161
|
-
expect { file[50_000] }.to raise_error(ArgumentError)
|
162
|
-
|
163
|
-
file.prepend do |f|
|
164
|
-
f << 'Hello large file'
|
165
|
-
end
|
166
|
-
|
167
|
-
expect(file[0]).to eq('Hello large file')
|
168
|
-
expect(file[1]).to eq('Line: 0')
|
169
|
-
expect(file[28_446]).to eq('Line: 28445')
|
170
|
-
expect(file[50_000]).to eq('Line: 49999')
|
171
|
-
end
|
172
|
-
end
|
173
|
-
end
|
174
|
-
end
|