-
Notifications
You must be signed in to change notification settings - Fork 21
Expand file tree
/
Copy pathsqlserver_config_spec.rb
More file actions
140 lines (122 loc) · 4.19 KB
/
sqlserver_config_spec.rb
File metadata and controls
140 lines (122 loc) · 4.19 KB
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
require 'spec_helper_acceptance'
require 'securerandom'
require 'erb'
host = find_only_one("sql_host")
# Get instance name
inst_name = ("MSSQL" + SecureRandom.hex(4)).upcase
# Get database name
db_name = ("DB" + SecureRandom.hex(4)).upcase
describe "sqlserver::config test", :node => host do
def ensure_sqlserver_instance(host,inst_name, ensure_val = 'present')
create_new_instance= <<-MANIFEST
sqlserver_instance{'#{inst_name}':
ensure => '#{ensure_val}',
source => 'H:',
features => [ 'SQL' ],
sql_sysadmin_accounts => ['Administrator'],
security_mode => 'SQL',
sa_pwd => 'Pupp3t1@',
}
MANIFEST
apply_manifest_on(host, create_new_instance) do |r|
expect(r.stderr).not_to match(/Error/i)
end
end
context "Testing sqlserver::config", {:testrail => ['89070', '89071', '89072', '89073']} do
before(:all) do
# Create new instance
ensure_sqlserver_instance(host, inst_name)
# get credentials for new config
@admin_user = "admin" + SecureRandom.hex(2)
@admin_pass = 'Pupp3t1@'
# get database user
@db_user = "dbuser" + SecureRandom.hex(2)
end
after(:all) do
# remove the newly created instance
ensure_sqlserver_instance(host, 'absent')
end
it "Create New Admin Login:" do
create_new_login = <<-MANIFEST
sqlserver::config{'#{inst_name}':
instance_name => '#{inst_name}',
admin_user => 'sa',
admin_pass => 'Pupp3t1@',
}
sqlserver::login{'#{@admin_user}':
instance => '#{inst_name}',
login_type => 'SQL_LOGIN',
login => '#{@admin_user}',
password => '#{@admin_pass}',
svrroles => {'sysadmin' => 1},
}
MANIFEST
apply_manifest_on(host, create_new_login) do |r|
expect(r.stderr).not_to match(/Error/i)
end
end
it "Validate New Config WITH using instance_name in sqlserver::config" do
pp = <<-MANIFEST
sqlserver::config{'#{inst_name}':
admin_user => '#{@admin_user}',
admin_pass => '#{@admin_pass}',
instance_name => '#{inst_name}',
}
sqlserver::database{'#{db_name}':
instance => '#{inst_name}',
}
MANIFEST
apply_manifest_on(host, pp) do |r|
expect(r.stderr).not_to match(/Error/i)
end
end
it "Validate new login and database actualy created" do
hostname = host.hostname
query = "USE #{db_name}; SELECT * from master..sysdatabases WHERE name = '#{db_name}'"
run_sql_query(host, {:query => query, :server => hostname, :instance => inst_name, \
:sql_admin_user => @admin_user, :sql_admin_pass => @admin_pass, :expected_row_count => 1})
end
it "Validate New Config WITHOUT using instance_name in sqlserver::config" do
pp = <<-MANIFEST
sqlserver::config{'#{inst_name}':
admin_user => '#{@admin_user}',
admin_pass => '#{@admin_pass}',
}
sqlserver::database{'#{db_name}':
instance => '#{inst_name}',
}
MANIFEST
apply_manifest_on(host, pp) do |r|
expect(r.stderr).not_to match(/Error/i)
end
end
it "Negative test: sqlserver::config without admin_user" do
pp = <<-MANIFEST
sqlserver::config{'#{inst_name}':
admin_pass => '#{@admin_pass}',
instance_name => '#{inst_name}',
}
sqlserver::database{'#{db_name}':
instance => '#{inst_name}',
}
MANIFEST
apply_manifest_on(host, pp, {:acceptable_exit_codes => [0,1]}) do |r|
expect(r.stderr).to match(/Error: Must pass admin_user to Sqlserver/)
end
end
it "Negative test: sqlserver::config without admin_pass" do
pp = <<-MANIFEST
sqlserver::config{'#{inst_name}':
admin_user => '#{@admin_user}',
instance_name => '#{inst_name}',
}
sqlserver::database{'#{db_name}':
instance => '#{inst_name}',
}
MANIFEST
apply_manifest_on(host, pp, {:acceptable_exit_codes => [0,1]}) do |r|
expect(r.stderr).to match(/Error: Must pass admin_pass to Sqlserver/)
end
end
end
end