-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathtest_import_vol_as_clone.py
621 lines (540 loc) · 32.1 KB
/
test_import_vol_as_clone.py
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
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
import pytest
import hpe_3par_kubernetes_manager as manager
from hpe3parclient.exceptions import HTTPBadRequest
from hpe3parclient.exceptions import HTTPForbidden
from hpe3parclient.exceptions import HTTPConflict
from hpe3parclient.exceptions import HTTPNotFound
import logging
import globals
from time import sleep
def test_import_vol_as_clone_sanity():
yml = '%s/import_vol_as_clone/import-vol-as-clone.yml' % globals.yaml_dir
sc = None
pvc_obj = None
pod_obj = None
vol_name = None
try:
# Create volume
"""hpe3par_cli = manager.get_3par_cli_client(yml)
array_ip, array_uname, array_pwd, protocol = manager.read_array_prop(yml)
hpe3par_version = manager.get_array_version(hpe3par_cli)
logging.getLogger().info("\n########################### test_import_cloned_vol test %s::%s::%s ###########################" %
(str(yml), protocol, hpe3par_version[0:5]))"""
yaml_values = manager.get_details_for_volume(yml)
options = prepare_options(yaml_values, globals.hpe3par_version)
# Create volume in array to be cloned and later imported to csi
vol_name = yaml_values['vol_name']
volume = None
volume, exception = create_vol_in_array(globals.hpe3par_cli, options, vol_name=vol_name, size=yaml_values['size'],
cpg_name=yaml_values['cpg'])
# assert volume is not None, "Volume %s is not created on array as %s. Terminating test." % (vol_name, exception)
if volume is None:
logging.getLogger().info("Volume %s is not created on array as %s. Terminating test." % (vol_name, exception))
return
logging.getLogger().info("Volume %s created successfully on array. Now Create clone..." % volume['name'])
#clone_volume, message = create_clone_in_array(globals.hpe3par_cli, source_vol_name=vol_name, option={'online': True, 'tpvv': True})
#logging.getLogger().info("Cloned volume is :: %s" % clone_volume)
#message = "Clone volume creation on array failed with error %s. Terminating test." % message
#assert clone_volume is not None, message
#clone_vol_name = clone_volume['name']
# Now import base of the clone to csi
#secret = manager.create_secret(yml)
sc = manager.create_sc(yml)
pvc = manager.create_pvc(yml)
logging.getLogger().info("Check in events if volume is created...")
status, message = manager.check_status_from_events(kind='PersistentVolumeClaim', name=pvc.metadata.name,
namespace=pvc.metadata.namespace, uid=pvc.metadata.uid)
assert status == 'ProvisioningSucceeded', f"{message}"
flag, pvc_obj = manager.check_status(30, pvc.metadata.name, kind='pvc', status='Bound',
namespace=pvc.metadata.namespace)
assert flag is True, "PVC %s for base volume %s status check timed out, not in Bound state yet..." % \
(pvc_obj.metadata.name, vol_name)
logging.getLogger().info("\n\nBase volume (after cloning at array) has been imported successfully to CSI.")
# Compare imported volume object with old volume object on array
pvc_crd = manager.get_pvc_crd(pvc_obj.spec.volume_name)
# logging.getLogger().info(pvc_crd)
imported_volume_name = manager.get_pvc_volume(pvc_crd)
assert manager.verify_clone_crd_status(pvc_obj.spec.volume_name) is True, \
"Clone PVC CRD is not yet completed"
csi_volume = manager.get_volume_from_array(globals.hpe3par_cli, imported_volume_name)
vol_has_diff, diff = compare_volumes(volume, csi_volume)
assert vol_has_diff is False, "After import volume properties are changed. Modified properties are %s" % diff
logging.getLogger().info("\nImported volume's properties have been verified successfully, all property values retain.")
pod_obj = create_verify_pod(yml, globals.hpe3par_cli, pvc_obj, imported_volume_name, globals.access_protocol)
finally:
# Now cleanup secret, sc, pv, pvc, pod
cleanup(None, sc, pvc_obj, pod_obj)
delete_vol_from_array(globals.hpe3par_cli, vol_name)
#if hpe3par_cli is not None:
# hpe3par_cli.logout()
def test_thin_true_comp_import_vol():
if globals.hpe3par_model is not "3PAR":
pytest.skip("Skipped on Primera/Alletra/Arcus array")
yml = "%s/import_vol_as_clone/import-vol-thin-true-comp.yml" % globals.yaml_dir
sc = None
pvc = None
pod = None
try:
"""hpe3par_cli = manager.get_3par_cli_client(yml)
array_ip, array_uname, array_pwd, protocol = manager.read_array_prop(yml)
logging.getLogger().info("\n########################### Import volume test %s::%s::%s ###########################" %
(str(yml), protocol, manager.get_array_version(hpe3par_cli)))"""
yaml_values = manager.get_details_for_volume(yml)
options = prepare_options(yaml_values, globals.hpe3par_version)
# Create volume in array to be cloned and later imported to csi
vol_name = yaml_values['vol_name']
volume, secret, sc, pvc, pod = create_import_verify_volume(yml, globals.hpe3par_cli, globals.access_protocol)
assert volume is not None,"Volume is not created on Array"
finally:
# Now cleanup secret, sc, pv, pvc, pod
cleanup(None, sc, pvc, pod)
delete_vol_from_array(globals.hpe3par_cli, vol_name)
#if hpe3par_cli is not None:
# hpe3par_cli.logout()
def test_thin_false_comp_import_vol():
yml = "%s/import_vol_as_clone/import-vol-thin-false-comp.yml" % globals.yaml_dir
sc = None
pvc = None
pod = None
try:
"""hpe3par_cli = manager.get_3par_cli_client(yml)
array_ip, array_uname, array_pwd, protocol = manager.read_array_prop(yml)
logging.getLogger().info("\n########################### Import volume test %s::%s::%s ###########################" %
(str(yml), protocol, manager.get_array_version(hpe3par_cli)))"""
yaml_values = manager.get_details_for_volume(yml)
options = prepare_options(yaml_values, globals.hpe3par_version)
# Create volume in array to be cloned and later imported to csi
vol_name = yaml_values['vol_name']
volume, secret, sc, pvc, pod = create_import_verify_volume(yml, globals.hpe3par_cli, globals.access_protocol)
finally:
# Now cleanup secret, sc, pv, pvc, pod
cleanup(None, sc, pvc, pod)
delete_vol_from_array(globals.hpe3par_cli, vol_name)
#if hpe3par_cli is not None:
# hpe3par_cli.logout()
def test_thin_absent_comp_import_vol():
yml = "%s/import_vol_as_clone/import-vol-thin-absent-comp.yml" % globals.yaml_dir
sc = None
pvc = None
pod = None
try:
"""hpe3par_cli = manager.get_3par_cli_client(yml)
array_ip, array_uname, array_pwd, protocol = manager.read_array_prop(yml)
logging.getLogger().info("\n########################### Import volume test %s::%s::%s ###########################" %
(str(yml), protocol, manager.get_array_version(hpe3par_cli)))"""
yaml_values = manager.get_details_for_volume(yml)
options = prepare_options(yaml_values, globals.hpe3par_version)
# Create volume in array to be cloned and later imported to csi
vol_name = yaml_values['vol_name']
volume, secret, sc, pvc, pod = create_import_verify_volume(yml, globals.hpe3par_cli, globals.access_protocol)
finally:
# Now cleanup secret, sc, pv, pvc, pod
cleanup(None, sc, pvc, pod)
delete_vol_from_array(globals.hpe3par_cli, vol_name)
#if hpe3par_cli is not None:
# hpe3par_cli.logout()
def test_full_true_comp_import_vol():
yml = "%s/import_vol_as_clone/import-vol-full-true-comp.yml" % globals.yaml_dir
sc = None
pvc = None
pod = None
try:
"""hpe3par_cli = manager.get_3par_cli_client(yml)
array_ip, array_uname, array_pwd, protocol = manager.read_array_prop(yml)
logging.getLogger().info("\n########################### Import volume test %s::%s::%s ###########################" %
(str(yml), protocol, manager.get_array_version(hpe3par_cli)))"""
yaml_values = manager.get_details_for_volume(yml)
options = prepare_options(yaml_values, globals.hpe3par_version)
# Create volume in array to be cloned and later imported to csi
vol_name = yaml_values['vol_name']
volume, secret, sc, pvc, pod = create_import_verify_volume(yml, globals.hpe3par_cli, globals.access_protocol)
finally:
# Now cleanup secret, sc, pv, pvc, pod
cleanup(None, sc, pvc, pod)
delete_vol_from_array(globals.hpe3par_cli, vol_name)
#if hpe3par_cli is not None:
# hpe3par_cli.logout()
def test_full_false_comp_import_vol():
yml = "%s/import_vol_as_clone/import-vol-full-false-comp.yml" % globals.yaml_dir
sc = None
pvc = None
pod = None
try:
"""hpe3par_cli = manager.get_3par_cli_client(yml)
array_ip, array_uname, array_pwd, protocol = manager.read_array_prop(yml)
logging.getLogger().info("\n########################### Import volume test %s::%s::%s ###########################" %
(str(yml), protocol, manager.get_array_version(hpe3par_cli)))"""
yaml_values = manager.get_details_for_volume(yml)
options = prepare_options(yaml_values, globals.hpe3par_version)
# Create volume in array to be cloned and later imported to csi
vol_name = yaml_values['vol_name']
volume, secret, sc, pvc, pod = create_import_verify_volume(yml, globals.hpe3par_cli, globals.access_protocol)
finally:
# Now cleanup secret, sc, pv, pvc, pod
cleanup(None, sc, pvc, pod)
delete_vol_from_array(globals.hpe3par_cli, vol_name)
#if hpe3par_cli is not None:
# hpe3par_cli.logout()
def test_full_absent_comp_import_vol():
yml = "%s/import_vol_as_clone/import-vol-full-absent-comp.yml" % globals.yaml_dir
sc = None
pvc = None
pod = None
try:
"""hpe3par_cli = manager.get_3par_cli_client(yml)
array_ip, array_uname, array_pwd, protocol = manager.read_array_prop(yml)
logging.getLogger().info("\n########################### Import volume test %s::%s::%s ###########################" %
(str(yml), protocol, manager.get_array_version(hpe3par_cli)))"""
yaml_values = manager.get_details_for_volume(yml)
options = prepare_options(yaml_values, globals.hpe3par_version)
# Create volume in array to be cloned and later imported to csi
vol_name = yaml_values['vol_name']
volume, secret, sc, pvc, pod = create_import_verify_volume(yml, globals.hpe3par_cli, globals.access_protocol)
finally:
# Now cleanup secret, sc, pv, pvc, pod
cleanup(None, sc, pvc, pod)
delete_vol_from_array(globals.hpe3par_cli, vol_name)
#if hpe3par_cli is not None:
# hpe3par_cli.logout()
def test_dedup_true_comp_import_vol():
yml = "%s/import_vol_as_clone/import-vol-dedup-true-comp.yml" % globals.yaml_dir
sc = None
pvc = None
pod = None
try:
"""hpe3par_cli = manager.get_3par_cli_client(yml)
array_ip, array_uname, array_pwd, protocol = manager.read_array_prop(yml)
logging.getLogger().info("\n########################### Import volume test %s::%s::%s ###########################" %
(str(yml), protocol, manager.get_array_version(hpe3par_cli)))"""
yaml_values = manager.get_details_for_volume(yml)
options = prepare_options(yaml_values, globals.hpe3par_version)
# Create volume in array to be cloned and later imported to csi
vol_name = yaml_values['vol_name']
volume, secret, sc, pvc, pod = create_import_verify_volume(yml, globals.hpe3par_cli, globals.access_protocol)
finally:
# Now cleanup secret, sc, pv, pvc, pod
cleanup(None, sc, pvc, pod)
delete_vol_from_array(globals.hpe3par_cli, vol_name)
#if hpe3par_cli is not None:
# hpe3par_cli.logout()
def test_dedup_false_comp_import_vol():
yml = "%s/import_vol_as_clone/import-vol-dedup-false-comp.yml" % globals.yaml_dir
sc = None
pvc = None
pod = None
try:
"""hpe3par_cli = manager.get_3par_cli_client(yml)
array_ip, array_uname, array_pwd, protocol = manager.read_array_prop(yml)
logging.getLogger().info("\n########################### Import volume test %s::%s::%s ###########################" %
(str(yml), protocol, manager.get_array_version(hpe3par_cli)))"""
yaml_values = manager.get_details_for_volume(yml)
options = prepare_options(yaml_values, globals.hpe3par_version)
# Create volume in array to be cloned and later imported to csi
vol_name = yaml_values['vol_name']
volume, secret, sc, pvc, pod = create_import_verify_volume(yml, globals.hpe3par_cli, globals.access_protocol)
finally:
# Now cleanup secret, sc, pv, pvc, pod
cleanup(None, sc, pvc, pod)
delete_vol_from_array(globals.hpe3par_cli, vol_name)
#if hpe3par_cli is not None:
# hpe3par_cli.logout()
def test_dedup_absent_comp_import_vol():
yml = "%s/import_vol_as_clone/import-vol-dedup-absent-comp.yml" % globals.yaml_dir
sc = None
pvc = None
pod = None
try:
"""hpe3par_cli = manager.get_3par_cli_client(yml)
array_ip, array_uname, array_pwd, protocol = manager.read_array_prop(yml)
logging.getLogger().info("\n########################### Import volume test %s::%s::%s ###########################" %
(str(yml), protocol, manager.get_array_version(hpe3par_cli)))"""
yaml_values = manager.get_details_for_volume(yml)
options = prepare_options(yaml_values, globals.hpe3par_version)
# Create volume in array to be cloned and later imported to csi
vol_name = yaml_values['vol_name']
volume, secret, sc, pvc, pod = create_import_verify_volume(yml, globals.hpe3par_cli, globals.access_protocol)
finally:
# Now cleanup secret, sc, pv, pvc, pod
cleanup(None, sc, pvc, pod)
delete_vol_from_array(globals.hpe3par_cli, vol_name)
#if hpe3par_cli is not None:
# hpe3par_cli.logout()
def test_full_false_comp_import_vol():
yml = "%s/import_vol_as_clone/import-vol-full-false-comp.yml" % globals.yaml_dir
sc = None
pvc = None
pod = None
try:
"""hpe3par_cli = manager.get_3par_cli_client(yml)
array_ip, array_uname, array_pwd, protocol = manager.read_array_prop(yml)
logging.getLogger().info("\n########################### Import volume test %s::%s::%s ###########################" %
(str(yml), protocol, manager.get_array_version(hpe3par_cli)))"""
yaml_values = manager.get_details_for_volume(yml)
options = prepare_options(yaml_values, globals.hpe3par_version)
# Create volume in array to be cloned and later imported to csi
vol_name = yaml_values['vol_name']
volume, secret, sc, pvc, pod = create_import_verify_volume(yml, globals.hpe3par_cli, globals.access_protocol)
finally:
# Now cleanup secret, sc, pv, pvc, pod
cleanup(None, sc, pvc, pod)
delete_vol_from_array(globals.hpe3par_cli, vol_name)
#if hpe3par_cli is not None:
# hpe3par_cli.logout()
def test_full_absent_comp_import_vol():
yml = "%s/import_vol_as_clone/import-vol-full-absent-comp.yml" % globals.yaml_dir
sc = None
pvc = None
pod = None
try:
"""hpe3par_cli = manager.get_3par_cli_client(yml)
array_ip, array_uname, array_pwd, protocol = manager.read_array_prop(yml)
logging.getLogger().info("\n########################### Import volume test %s::%s::%s ###########################" %
(str(yml), protocol, manager.get_array_version(hpe3par_cli)))"""
yaml_values = manager.get_details_for_volume(yml)
options = prepare_options(yaml_values, globals.hpe3par_version)
# Create volume in array to be cloned and later imported to csi
vol_name = yaml_values['vol_name']
volume, secret, sc, pvc, pod = create_import_verify_volume(yml, globals.hpe3par_cli, globals.access_protocol)
finally:
# Now cleanup secret, sc, pv, pvc, pod
cleanup(None, sc, pvc, pod)
delete_vol_from_array(globals.hpe3par_cli, vol_name)
#if hpe3par_cli is not None:
# hpe3par_cli.logout()
def delete_vol_from_array(hpe3par_cli, vol_name):
try:
logging.getLogger().info("In delete_vol_from_array() :: vol_name :: %s" % vol_name)
volume = manager.get_volume_from_array(hpe3par_cli, vol_name)
if volume is not None:
hpe3par_cli.deleteVolume(vol_name)
except (HTTPConflict, HTTPNotFound, HTTPForbidden) as e:
logging.getLogger().info("Exception from delete_vol_from_array :: %s " % e)
except Exception as e:
logging.getLogger().info("Exception in delete_vol_from_array :: %s" % e)
#logging.error("Exception in test_publish :: %s" % e)
raise e
def cleanup(secret, sc, pvc, pod):
logging.getLogger().info("====== cleanup :START =========")
#logging.info("====== cleanup after failure:START =========")
logging.getLogger().info("pod :: %s, pvc :: %s, sc :: %s" % (pod, pvc, sc))
if pod is not None and manager.check_if_deleted(2, pod.metadata.name, "Pod", namespace=pod.metadata.namespace) is False:
manager.delete_pod(pod.metadata.name, pod.metadata.namespace)
if pvc is not None and manager.check_if_deleted(2, pvc.metadata.name, "PVC", namespace=pvc.metadata.namespace) is False:
manager.delete_pvc(pvc.metadata.name)
"""assert manager.check_if_crd_deleted(pvc.spec.volume_name, "hpevolumeinfos") is True, \
"CRD %s of %s is not deleted yet. Taking longer..." % (pvc.spec.volume_name, 'hpevolumeinfos')"""
flag = manager.check_if_crd_deleted(pvc.spec.volume_name, "hpevolumeinfos")
if flag is False:
logging.getLogger().error("CRD %s of %s is not deleted yet. Taking longer..." % (pvc.spec.volume_name, 'hpevolumeinfos'))
if sc is not None and manager.check_if_deleted(2, sc.metadata.name, "SC", sc.metadata.namespace) is False:
manager.delete_sc(sc.metadata.name)
"""if secret is not None and manager.check_if_deleted(2, secret.metadata.name, "Secret", namespace=secret.metadata.namespace) is False:
manager.delete_secret(secret.metadata.name, secret.metadata.namespace)"""
logging.getLogger().info("====== cleanup :END =========")
#logging.info("====== cleanup after failure:END =========")
def cleanup_crd(snapshot_name, snapclass_name):
logging.getLogger().info("====== cleanup_crd :START =========")
# logging.info("====== cleanup after failure:START =========")
if snapshot_name is not None:# and manager.check_if_crd_deleted(snapshot_name, "volumesnapshots") is False:
manager.delete_snapshot(snapshot_name)
if snapclass_name is not None:# and manager.check_if_crd_deleted(snapclass_name, "volumesnapshotclasses") is False:
manager.delete_snapclass(snapclass_name)
logging.getLogger().info("====== cleanup_crd :END =========")
# logging.info("====== cleanup after failure:END =========")
def delete_resources(hpe3par_cli, secret, sc, pvc, pod, protocol):
timeout = 600
try:
assert manager.delete_pod(pod.metadata.name, pod.metadata.namespace), "Pod %s is not deleted yet " % \
pod.metadata.name
assert manager.check_if_deleted(timeout, pod.metadata.name, "Pod", namespace=pod.metadata.namespace) is True, \
"Pod %s is not deleted yet " % pod.metadata.name
pvc_crd = manager.get_pvc_crd(pvc.spec.volume_name)
# logging.getLogger().info(pvc_crd)
volume_name = manager.get_pvc_volume(pvc_crd)
if protocol == 'iscsi':
hpe3par_vlun = manager.get_3par_vlun(hpe3par_cli, volume_name)
iscsi_ips = manager.get_iscsi_ips(hpe3par_cli)
flag, disk_partition = manager.verify_by_path(iscsi_ips, pod.spec.node_name)
flag, ip = manager.verify_deleted_partition(iscsi_ips, pod.spec.node_name)
assert flag is True, "Partition(s) not cleaned after volume deletion for iscsi-ip %s " % ip
paths = manager.verify_deleted_multipath_entries(pod.spec.node_name, hpe3par_vlun)
assert paths is None or len(paths) == 0, "Multipath entries are not cleaned"
# partitions = manager.verify_deleted_lsscsi_entries(pod_obj.spec.node_name, disk_partition)
# assert len(partitions) == 0, "lsscsi verificatio failed for vlun deletion"
flag = manager.verify_deleted_lsscsi_entries(pod.spec.node_name, disk_partition)
logging.getLogger().info("flag after deleted lsscsi verificatio is %s " % flag)
assert flag, "lsscsi verification failed for vlun deletion"
# Verify crd for unpublished status
try:
assert manager.verify_pvc_crd_published(pvc.spec.volume_name) is False, \
"PVC CRD %s Published is true after Pod is deleted" % pvc.spec.volume_name
logging.getLogger().info("PVC CRD published is false after pod deletion.")
# logging.warning("PVC CRD published is false after pod deletion.")
except Exception as e:
logging.getLogger().info("Resuming test after failure of publishes status check for pvc crd... \n%s" % e)
# logging.error("Resuming test after failure of publishes status check for pvc crd... \n%s" % e)
assert manager.delete_pvc(pvc.metadata.name)
assert manager.check_if_deleted(timeout, pvc.metadata.name, "PVC", namespace=pvc.metadata.namespace) is True, \
"PVC %s is not deleted yet " % pvc.metadata.name
# pvc_crd = manager.get_pvc_crd(pvc_obj.spec.volume_name)
# logging.getLogger().info("PVC crd after PVC object deletion :: %s " % pvc_crd)
assert manager.check_if_crd_deleted(pvc.spec.volume_name, "hpevolumeinfos") is True, \
"CRD %s of %s is not deleted yet. Taking longer..." % (pvc.spec.volume_name, 'hpevolumeinfos')
sleep(30)
assert manager.verify_delete_volume_on_3par(hpe3par_cli, volume_name), \
"Volume %s from 3PAR for PVC %s is not deleted" % (volume_name, pvc.metadata.name)
assert manager.delete_sc(sc.metadata.name) is True
assert manager.check_if_deleted(timeout, sc.metadata.name, "SC") is True, "SC %s is not deleted yet " \
% sc.metadata.name
assert manager.delete_secret(secret.metadata.name, secret.metadata.namespace) is True
assert manager.check_if_deleted(timeout, secret.metadata.name, "Secret",
namespace=secret.metadata.namespace) is True, \
"Secret %s is not deleted yet " % secret.metadata.name
except Exception as e:
logging.getLogger().info("Exception in delete_resource() :: %s " % e)
def prepare_options(yaml_values, hpe3par_version):
options = {}
if 'comment' in yaml_values.keys():
options['comment'] = yaml_values['comment']
if 'snapCPG' in yaml_values.keys():
options['snapCPG'] = yaml_values['snapCPG']
if yaml_values['provisioning'] == "tpvv":
options['tpvv'] = True
if yaml_values['provisioning'] == "dedup":
options['tdvv'] = True
if yaml_values['provisioning'] == "reduce":
options['tdvv'] = True
if 'compression' in yaml_values.keys():
if yaml_values['compression'] is True or yaml_values['compression'] == 'true':
options['compression'] = True
if yaml_values['compression'] is False or yaml_values['compression'] == 'false':
options['compression'] = False
return options
def create_vol_in_array(hpe3par_cli, options, vol_name='test-importVol', cpg_name='CI_CPG', size=10240):
try:
logging.getLogger().info("In create_vol_in_array() :: vol_name :: %s, cpg_name :: %s, size :: %s, options :: %s" % (vol_name,
cpg_name, size, options))
response = hpe3par_cli.createVolume(vol_name, cpg_name, size, options)
logging.getLogger().info("Create volume response %s" % response)
volume = manager.get_volume_from_array(hpe3par_cli, vol_name)
return volume, None
except (HTTPConflict, HTTPBadRequest, HTTPForbidden) as e:
logging.getLogger().info("Exception from create_vol_in_array :: %s " % e)
return None, e
except Exception as e:
logging.getLogger().info("Exception in create_vol_in_array :: %s" % e)
#logging.error("Exception in test_publish :: %s" % e)
raise e
def compare_volumes(vol1, vol2):
logging.getLogger().info("In compare_volumes()")
logging.getLogger().info("vol1 :: %s" % vol1)
logging.getLogger().info("vol2 :: %s" % vol2)
flag = False
diff_keys = {}
try:
for key, value in vol1.items():
# if key == 'name' or key == 'links':
# continue
if key not in ['deduplicationState', 'compressionState', 'provisioningType', 'copyType', 'userCPG',
'snapCPG']:
continue
if key in vol2 and vol1[key] != vol2[key]:
diff_keys[key] = value
flag = True
return flag, diff_keys
except Exception as e:
logging.getLogger().info("Exception in compare_volumes :: %s" % e)
#logging.error("Exception in test_publish :: %s" % e)
raise e
def create_verify_pod(yml, hpe3par_cli, pvc_obj, imported_volume_name, protocol, pod_run=True, pod_message=''):
pod = manager.create_pod(yml)
flag, pod_obj = manager.check_status(None, pod.metadata.name, kind='pod', status='Running',
namespace=pod.metadata.namespace)
logging.getLogger().info("pod_run :: %s " % pod_run)
logging.getLogger().info("pod_message :: %s " % pod_message)
logging.getLogger().info("hpe3par_cli :: %s " % hpe3par_cli)
logging.getLogger().info("flag :: %s " % flag)
#logging.getLogger().info("pod_obj :: %s " % pod_obj)
#logging.getLogger().info("pvc_obj :: %s " % pvc_obj)
if pod_run:
assert flag is True, "Published imported volume via pod %s, but it is not in Running state yet..." % pod.metadata.name
else:
assert flag is False
logging.getLogger().info(pod_message)
return pod_obj
# Verify crd fpr published status
assert manager.verify_pvc_crd_published(pvc_obj.spec.volume_name) is True, \
"PVC CRD %s Published is false after Pod is running" % pvc_obj.spec.volume_name
logging.getLogger().info("PVC CRD %s Published is True after Pod is running" % pvc_obj.spec.volume_name)
hpe3par_vlun = manager.get_3par_vlun(hpe3par_cli, imported_volume_name)
assert manager.verify_pod_node(hpe3par_vlun, pod_obj) is True, \
"Node for pod received from 3par and cluster do not match"
logging.getLogger().info("Node for pod received from 3par and cluster do match")
# verify_vlun(hpe3par_cli, hpe3par_vlun, pod_obj, protocol)
return pod_obj
def create_import_verify_volume(yml, hpe3par_cli, protocol, publish=True, pvc_bound=True, pvc_message='', pod_run=True, pod_message=''):
secret = None
sc = None
pvc_obj = None
pod_obj = None
volume = None
# Create volume
"""hpe3par_cli = manager.get_3par_cli_client(yml)
array_ip, array_uname, array_pwd, protocol = manager.read_array_prop(yml)
hpe3par_version = manager.get_array_version(hpe3par_cli)
logging.getLogger().info("\n########################### Import volume test %s::%s::%s ###########################" %
(str(yml), protocol, hpe3par_version[0:5]))"""
hpe3par_version = manager.get_array_version(hpe3par_cli)
yaml_values = manager.get_details_for_volume(yml)
if yaml_values['provisioning'].lower() == 'full' and hpe3par_version[0:1] == '4':
logging.getLogger().info("Full Provisioning not supported on primera. Terminating test.")
return None, None, None, None, None
options = prepare_options(yaml_values, hpe3par_version)
# Create volume in array to be imported
logging.getLogger().info("Options to 3par cli for creating volume :: %s " % options)
volume, exception = create_vol_in_array(hpe3par_cli, options, vol_name=yaml_values['vol_name'],
size=yaml_values['size'], cpg_name=yaml_values['cpg'])
# assert volume is not None, "Volume %s is not created on array as %s. Terminating test." % (vol_name, exception)
if volume is None:
logging.getLogger().info("Volume %s is not created on array as %s. Terminating test." % (yaml_values['vol_name'], exception))
return None, None, None, None, None
logging.getLogger().info("Volume %s created successfully on array. Now import it to CSI..." % volume['name'])
# Import volume now in CSI
#secret = manager.create_secret(yml)
sc = manager.create_sc(yml)
pvc = manager.create_pvc(yml)
logging.getLogger().info("Check in events if volume is created...")
status, message = manager.check_status_from_events(kind='PersistentVolumeClaim', name=pvc.metadata.name,
namespace=pvc.metadata.namespace, uid=pvc.metadata.uid)
#logging.getLogger().info(status)
#logging.getLogger().info(message)
if pvc_bound:
assert status == 'ProvisioningSucceeded', f"{message}"
flag, pvc_obj = manager.check_status(30, pvc.metadata.name, kind='pvc', status='Bound',
namespace=pvc.metadata.namespace)
assert flag is True, "PVC %s status check timed out, not in Bound state yet..." % pvc_obj.metadata.name
# Compare imported volume object with old volume object on array
pvc_crd = manager.get_pvc_crd(pvc_obj.spec.volume_name)
# logging.getLogger().info(pvc_crd)
imported_volume_name = manager.get_pvc_volume(pvc_crd)
assert manager.verify_clone_crd_status(pvc_obj.spec.volume_name) is True, \
"Clone PVC CRD is not yet completed"
csi_volume = manager.get_volume_from_array(globals.hpe3par_cli, imported_volume_name)
csi_volume = manager.get_volume_from_array(hpe3par_cli, imported_volume_name)
vol_has_diff, diff = compare_volumes(volume, csi_volume)
assert vol_has_diff is False, "After import volume properties are changed. Modified properties are %s" % diff
logging.getLogger().info("\nImported volume's properties have been verified successfully, all property values retain.")
else:
pvc_obj = pvc
"""assert status == 'ProvisioningFailed', "Imported volume that starts from PVC (%s)" % yaml_values['vol_name']
logging.getLogger().info("\n\nCould not import volume starts with PVC, as expected.")"""
assert status == 'ProvisioningFailed', "Imported volume that %s" % pvc_message
logging.getLogger().info("\n\nCould not import volume %s, as expected." % pvc_message)
# return status, "\n\nCould not import volume starts with PVC, as expected.", secret, pvc_obj, None
# Now publish this volume and verify vluns
if publish is True:
if protocol is None: # not specified at command line
# read it from sc yml
protocol = manager.read_protocol(yml)
pod_obj = create_verify_pod(yml, hpe3par_cli, pvc_obj, imported_volume_name, protocol, pod_run, pod_message)
return volume, secret, sc, pvc_obj, pod_obj