Merge "Optionaly require keypair on ng-launch-instance"
This commit is contained in:
commit
68411394b3
@ -25,7 +25,8 @@
|
|||||||
'horizon.dashboard.project.workflow.launch-instance.basePath',
|
'horizon.dashboard.project.workflow.launch-instance.basePath',
|
||||||
'launchInstanceModel',
|
'launchInstanceModel',
|
||||||
'$modal',
|
'$modal',
|
||||||
'horizon.framework.widgets.toast.service'
|
'horizon.framework.widgets.toast.service',
|
||||||
|
'horizon.app.core.openstack-service-api.settings'
|
||||||
];
|
];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -34,7 +35,13 @@
|
|||||||
* @description
|
* @description
|
||||||
* Allows selection of key pairs.
|
* Allows selection of key pairs.
|
||||||
*/
|
*/
|
||||||
function LaunchInstanceKeypairController(basePath, launchInstanceModel, $modal, toastService) {
|
function LaunchInstanceKeypairController(
|
||||||
|
basePath,
|
||||||
|
launchInstanceModel,
|
||||||
|
$modal,
|
||||||
|
toastService,
|
||||||
|
settingsService
|
||||||
|
) {
|
||||||
var ctrl = this;
|
var ctrl = this;
|
||||||
|
|
||||||
ctrl.isKeypairCreated = false;
|
ctrl.isKeypairCreated = false;
|
||||||
@ -46,6 +53,7 @@
|
|||||||
ctrl.allocateNewKeyPair = allocateNewKeyPair;
|
ctrl.allocateNewKeyPair = allocateNewKeyPair;
|
||||||
ctrl.createKeyPair = createKeyPair;
|
ctrl.createKeyPair = createKeyPair;
|
||||||
ctrl.importKeyPair = importKeyPair;
|
ctrl.importKeyPair = importKeyPair;
|
||||||
|
ctrl.setKeypairRequired = setKeypairRequired;
|
||||||
|
|
||||||
ctrl.tableData = {
|
ctrl.tableData = {
|
||||||
available: launchInstanceModel.keypairs,
|
available: launchInstanceModel.keypairs,
|
||||||
@ -60,6 +68,12 @@
|
|||||||
maxAllocation: 1
|
maxAllocation: 1
|
||||||
};
|
};
|
||||||
|
|
||||||
|
ctrl.isKeypairRequired = 0;
|
||||||
|
|
||||||
|
settingsService.getSetting(
|
||||||
|
'OPENSTACK_HYPERVISOR_FEATURES.requires_keypair'
|
||||||
|
).then(setKeypairRequired);
|
||||||
|
|
||||||
//////////
|
//////////
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -138,6 +152,17 @@
|
|||||||
function getName(item) {
|
function getName(item) {
|
||||||
return item.name;
|
return item.name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ngdoc function
|
||||||
|
* @name setKeypairRequired
|
||||||
|
* @description
|
||||||
|
* Set if a KeyPair is required based on the settings
|
||||||
|
* @param {Boolean} setting The requires_keypair setting
|
||||||
|
*/
|
||||||
|
function setKeypairRequired(setting) {
|
||||||
|
ctrl.isKeypairRequired = setting ? 1 : 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
})();
|
})();
|
||||||
|
@ -19,18 +19,35 @@
|
|||||||
describe('Launch Instance Keypair Step', function() {
|
describe('Launch Instance Keypair Step', function() {
|
||||||
|
|
||||||
describe('LaunchInstanceKeypairController', function() {
|
describe('LaunchInstanceKeypairController', function() {
|
||||||
var ctrl;
|
var ctrl, q, settings;
|
||||||
var $modal = { open: angular.noop };
|
var $modal = { open: angular.noop };
|
||||||
var toastServiceMock = {add: angular.noop};
|
var toastServiceMock = {add: angular.noop};
|
||||||
|
|
||||||
beforeEach(module('horizon.dashboard.project'));
|
beforeEach(module('horizon.dashboard.project'));
|
||||||
|
|
||||||
|
beforeEach(function() {
|
||||||
|
settings = {
|
||||||
|
OPENSTACK_HYPERVISOR_FEATURES: {
|
||||||
|
requires_keypair: false
|
||||||
|
}
|
||||||
|
};
|
||||||
|
});
|
||||||
|
|
||||||
beforeEach(module(function ($provide) {
|
beforeEach(module(function ($provide) {
|
||||||
$provide.value('$modal', $modal);
|
$provide.value('$modal', $modal);
|
||||||
$provide.value('horizon.framework.widgets.toast.service', toastServiceMock);
|
$provide.value('horizon.framework.widgets.toast.service', toastServiceMock);
|
||||||
|
$provide.value('horizon.app.core.openstack-service-api.settings', {
|
||||||
|
getSetting: function(setting) {
|
||||||
|
setting = setting.split('.');
|
||||||
|
var deferred = q.defer();
|
||||||
|
deferred.resolve(settings[setting[0]][setting[1]]);
|
||||||
|
return deferred.promise;
|
||||||
|
}
|
||||||
|
});
|
||||||
}));
|
}));
|
||||||
|
|
||||||
beforeEach(inject(function($controller) {
|
beforeEach(inject(function($controller, $q) {
|
||||||
|
q = $q;
|
||||||
var model = {
|
var model = {
|
||||||
newInstanceSpec: {
|
newInstanceSpec: {
|
||||||
key_pair: ['key1']
|
key_pair: ['key1']
|
||||||
@ -157,6 +174,19 @@
|
|||||||
|
|
||||||
expect(ctrl.tableData.allocated[0].name).toEqual("newKeypair");
|
expect(ctrl.tableData.allocated[0].name).toEqual("newKeypair");
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('defines isKeypairRequired', function() {
|
||||||
|
expect(ctrl.isKeypairRequired).toBeDefined();
|
||||||
|
expect(ctrl.isKeypairRequired).toBe(0);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('sets isKeypairRequired properly', function() {
|
||||||
|
expect(ctrl.isKeypairRequired).toBeDefined();
|
||||||
|
ctrl.setKeypairRequired(true);
|
||||||
|
expect(ctrl.isKeypairRequired).toBe(1);
|
||||||
|
ctrl.setKeypairRequired(false);
|
||||||
|
expect(ctrl.isKeypairRequired).toBe(0);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
|
@ -31,7 +31,7 @@
|
|||||||
limits="ctrl.tableLimits">
|
limits="ctrl.tableLimits">
|
||||||
|
|
||||||
<!-- Key Pairs Allocated-->
|
<!-- Key Pairs Allocated-->
|
||||||
<allocated>
|
<allocated validate-number-min="ctrl.isKeypairRequired" ng-model="ctrl.tableData.allocated.length">
|
||||||
<table st-table="ctrl.tableData.displayedAllocated"
|
<table st-table="ctrl.tableData.displayedAllocated"
|
||||||
st-safe-src="ctrl.tableData.allocated" hz-table
|
st-safe-src="ctrl.tableData.allocated" hz-table
|
||||||
class="table table-striped table-rsp table-detail">
|
class="table table-striped table-rsp table-detail">
|
||||||
@ -129,6 +129,5 @@
|
|||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
</available>
|
</available>
|
||||||
|
|
||||||
</transfer-table> <!-- End Key Pairs Table -->
|
</transfer-table> <!-- End Key Pairs Table -->
|
||||||
</div> <!-- End Controller -->
|
</div> <!-- End Controller -->
|
||||||
|
Loading…
Reference in New Issue
Block a user