Merge pull request #46014 from vrushch/rbd_form_fix

mgr/dashboard: rbd striping setting pre-population and pop-over

Reviewed-by: Pegonzal <NOT@FOUND>
Reviewed-by: Ernesto Puerta <epuertat@redhat.com>
Reviewed-by: Nizamudeen A <nia@redhat.com>
Reviewed-by: Pere Diaz Bou <pdiazbou@redhat.com>
This commit is contained in:
Pere Diaz Bou 2022-07-14 18:20:24 +02:00 committed by GitHub
commit 45ecfc6ac7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 12 additions and 6 deletions

View File

@ -319,7 +319,7 @@
<div class="form-group row"> <div class="form-group row">
<label i18n <label i18n
class="cd-col-form-label" class="cd-col-form-label"
for="size">Object size</label> for="size">Object size<cd-helper>Objects in the Ceph Storage Cluster have a maximum configurable size (e.g., 2MB, 4MB, etc.). The object size should be large enough to accommodate many stripe units, and should be a multiple of the stripe unit.</cd-helper></label>
<div class="cd-col-form-input"> <div class="cd-col-form-input">
<select id="obj_size" <select id="obj_size"
name="obj_size" name="obj_size"
@ -336,7 +336,7 @@
<label class="cd-col-form-label" <label class="cd-col-form-label"
[ngClass]="{'required': rbdForm.getValue('stripingCount')}" [ngClass]="{'required': rbdForm.getValue('stripingCount')}"
for="stripingUnit" for="stripingUnit"
i18n>Stripe unit</label> i18n>Stripe unit<cd-helper>Stripes have a configurable unit size (e.g., 64kb). The Ceph Client divides the data it will write to objects into equally sized stripe units, except for the last stripe unit. A stripe width, should be a fraction of the Object Size so that an object may contain many stripe units.</cd-helper></label>
<div class="cd-col-form-input"> <div class="cd-col-form-input">
<select id="stripingUnit" <select id="stripingUnit"
name="stripingUnit" name="stripingUnit"
@ -361,7 +361,7 @@
<label class="cd-col-form-label" <label class="cd-col-form-label"
[ngClass]="{'required': rbdForm.getValue('stripingUnit')}" [ngClass]="{'required': rbdForm.getValue('stripingUnit')}"
for="stripingCount" for="stripingCount"
i18n>Stripe count</label> i18n>Stripe count<cd-helper>The Ceph Client writes a sequence of stripe units over a series of objects determined by the stripe count. The series of objects is called an object set. After the Ceph Client writes to the last object in the object set, it returns to the first object in the object set.</cd-helper></label>
<div class="cd-col-form-input"> <div class="cd-col-form-input">
<input id="stripingCount" <input id="stripingCount"
name="stripingCount" name="stripingCount"

View File

@ -99,6 +99,11 @@ export class RbdFormComponent extends CdForm implements OnInit {
'16 MiB', '16 MiB',
'32 MiB' '32 MiB'
]; ];
defaultStripingUnit = '4 MiB';
defaultStripingCount = 1;
action: string; action: string;
resource: string; resource: string;
private rbdImage = new ReplaySubject(1); private rbdImage = new ReplaySubject(1);
@ -193,8 +198,8 @@ export class RbdFormComponent extends CdForm implements OnInit {
validators: [Validators.pattern(/^([0-9]+)d|([0-9]+)h|([0-9]+)m$/)] // check schedule interval to be in format - 1d or 1h or 1m validators: [Validators.pattern(/^([0-9]+)d|([0-9]+)h|([0-9]+)m$/)] // check schedule interval to be in format - 1d or 1h or 1m
}), }),
mirroringMode: new FormControl(this.mirroringOptions[0]), mirroringMode: new FormControl(this.mirroringOptions[0]),
stripingUnit: new FormControl(null), stripingUnit: new FormControl(this.defaultStripingUnit),
stripingCount: new FormControl(null, { stripingCount: new FormControl(this.defaultStripingCount, {
updateOn: 'blur' updateOn: 'blur'
}) })
}, },
@ -437,7 +442,8 @@ export class RbdFormComponent extends CdForm implements OnInit {
objectSizeControl.value != null ? objectSizeControl.value : this.defaultObjectSize objectSizeControl.value != null ? objectSizeControl.value : this.defaultObjectSize
); );
const stripingCountControl = formGroup.get('stripingCount'); const stripingCountControl = formGroup.get('stripingCount');
const stripingCount = stripingCountControl.value != null ? stripingCountControl.value : 1; const stripingCount =
stripingCountControl.value != null ? stripingCountControl.value : this.defaultStripingCount;
let sizeControlErrors = null; let sizeControlErrors = null;
if (sizeControl.value === null) { if (sizeControl.value === null) {
sizeControlErrors = { required: true }; sizeControlErrors = { required: true };