GUI -- Created initial device view
Change-Id: Ie9b2a4e743d7a8070c3dfe736ad5a953547bd2f9
Showing
8 changed files
with
271 additions
and
0 deletions
| ... | @@ -5,4 +5,5 @@ | ... | @@ -5,4 +5,5 @@ |
| 5 | <ul> | 5 | <ul> |
| 6 | <li> <a ng-click="navCtrl.hideNav()" href="#/sample">Sample View</a></li> | 6 | <li> <a ng-click="navCtrl.hideNav()" href="#/sample">Sample View</a></li> |
| 7 | <li> <a ng-click="navCtrl.hideNav()" href="#/topo">Topology View</a></li> | 7 | <li> <a ng-click="navCtrl.hideNav()" href="#/topo">Topology View</a></li> |
| 8 | + <li> <a ng-click="navCtrl.hideNav()" href="#/device">Device View</a></li> | ||
| 8 | </ul> | 9 | </ul> | ... | ... |
| ... | @@ -57,12 +57,14 @@ | ... | @@ -57,12 +57,14 @@ |
| 57 | <!-- {INJECTED-JAVASCRIPT} --> | 57 | <!-- {INJECTED-JAVASCRIPT} --> |
| 58 | <script src="view/sample/sample.js"></script> | 58 | <script src="view/sample/sample.js"></script> |
| 59 | <script src="view/topo/topo.js"></script> | 59 | <script src="view/topo/topo.js"></script> |
| 60 | + <script src="view/device/device.js"></script> | ||
| 60 | <!-- TODO: inject javascript refs server-side --> | 61 | <!-- TODO: inject javascript refs server-side --> |
| 61 | 62 | ||
| 62 | <!-- This is where contributed stylesheets will get injected --> | 63 | <!-- This is where contributed stylesheets will get injected --> |
| 63 | <!-- {INJECTED-STYLESHEETS} --> | 64 | <!-- {INJECTED-STYLESHEETS} --> |
| 64 | <link rel="stylesheet" href="view/sample/sample.css"> | 65 | <link rel="stylesheet" href="view/sample/sample.css"> |
| 65 | <link rel="stylesheet" href="view/topo/topo.css"> | 66 | <link rel="stylesheet" href="view/topo/topo.css"> |
| 67 | + <link rel="stylesheet" href="view/device/device.css"> | ||
| 66 | <!-- TODO: inject style-sheet refs server-side --> | 68 | <!-- TODO: inject style-sheet refs server-side --> |
| 67 | </head> | 69 | </head> |
| 68 | <body class="light" ng-app="onosApp"> | 70 | <body class="light" ng-app="onosApp"> | ... | ... |
| ... | @@ -30,6 +30,7 @@ | ... | @@ -30,6 +30,7 @@ |
| 30 | // NOTE: 'ov' == 'Onos View'... | 30 | // NOTE: 'ov' == 'Onos View'... |
| 31 | 'ovSample', | 31 | 'ovSample', |
| 32 | 'ovTopo', | 32 | 'ovTopo', |
| 33 | + 'ovDevice', | ||
| 33 | // (end of view modules) | 34 | // (end of view modules) |
| 34 | 35 | ||
| 35 | // core modules... | 36 | // core modules... |
| ... | @@ -81,6 +82,11 @@ | ... | @@ -81,6 +82,11 @@ |
| 81 | controllerAs: 'ctrl', | 82 | controllerAs: 'ctrl', |
| 82 | templateUrl: 'view/topo/topo.html' | 83 | templateUrl: 'view/topo/topo.html' |
| 83 | }) | 84 | }) |
| 85 | + .when('/device', { | ||
| 86 | + controller: 'OvDeviceCtrl', | ||
| 87 | + controllerAs: 'ctrl', | ||
| 88 | + templateUrl: 'view/device/device.html' | ||
| 89 | + }) | ||
| 84 | .otherwise({ | 90 | .otherwise({ |
| 85 | redirectTo: '/' | 91 | redirectTo: '/' |
| 86 | }) | 92 | }) | ... | ... |
| 1 | +/* | ||
| 2 | + * Copyright 2015 Open Networking Laboratory | ||
| 3 | + * | ||
| 4 | + * Licensed under the Apache License, Version 2.0 (the "License"); | ||
| 5 | + * you may not use this file except in compliance with the License. | ||
| 6 | + * You may obtain a copy of the License at | ||
| 7 | + * | ||
| 8 | + * http://www.apache.org/licenses/LICENSE-2.0 | ||
| 9 | + * | ||
| 10 | + * Unless required by applicable law or agreed to in writing, software | ||
| 11 | + * distributed under the License is distributed on an "AS IS" BASIS, | ||
| 12 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
| 13 | + * See the License for the specific language governing permissions and | ||
| 14 | + * limitations under the License. | ||
| 15 | + */ | ||
| 16 | + | ||
| 17 | +/* | ||
| 18 | + ONOS GUI -- Sample View -- CSS file | ||
| 19 | + | ||
| 20 | + @author Simon Hunt | ||
| 21 | + */ | ||
| 22 | + | ||
| 23 | +#ov-device table { | ||
| 24 | + border: 1px; | ||
| 25 | + /*color: darkorange;*/ | ||
| 26 | +} | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
| 1 | +<!-- Device partial HTML --> | ||
| 2 | +<div id="ov-device"> | ||
| 3 | + <h2>Device View</h2> | ||
| 4 | + | ||
| 5 | + <table> | ||
| 6 | + <tr ng-repeat="dev in ctrl.deviceData"> | ||
| 7 | + <!-- add more property fields for table from device data --> | ||
| 8 | + <td>{{dev.id}}</td> | ||
| 9 | + <td>{{dev.mfr}}</td> | ||
| 10 | + <td>{{dev.hw}}</td> | ||
| 11 | + <td>{{dev.sw}}</td> | ||
| 12 | + </tr> | ||
| 13 | + </table> | ||
| 14 | + | ||
| 15 | +</div> |
| 1 | +/* | ||
| 2 | + * Copyright 2015 Open Networking Laboratory | ||
| 3 | + * | ||
| 4 | + * Licensed under the Apache License, Version 2.0 (the "License"); | ||
| 5 | + * you may not use this file except in compliance with the License. | ||
| 6 | + * You may obtain a copy of the License at | ||
| 7 | + * | ||
| 8 | + * http://www.apache.org/licenses/LICENSE-2.0 | ||
| 9 | + * | ||
| 10 | + * Unless required by applicable law or agreed to in writing, software | ||
| 11 | + * distributed under the License is distributed on an "AS IS" BASIS, | ||
| 12 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
| 13 | + * See the License for the specific language governing permissions and | ||
| 14 | + * limitations under the License. | ||
| 15 | + */ | ||
| 16 | + | ||
| 17 | +/* | ||
| 18 | + ONOS GUI -- Sample View Module | ||
| 19 | + | ||
| 20 | + @author Simon Hunt | ||
| 21 | + @author Bri Prebilic Cole | ||
| 22 | + */ | ||
| 23 | + | ||
| 24 | +(function () { | ||
| 25 | + 'use strict'; | ||
| 26 | + | ||
| 27 | + var urlSuffix = '/onos/v1/devices'; | ||
| 28 | + | ||
| 29 | + // TODO : refactor into remote service | ||
| 30 | + function buildUrl($loc) { | ||
| 31 | + return $loc.protocol() + '://' + $loc.host() + ':' + $loc.port(); | ||
| 32 | + } | ||
| 33 | + | ||
| 34 | + angular.module('ovDevice', []) | ||
| 35 | + .controller('OvDeviceCtrl', ['$log', '$http', '$location', | ||
| 36 | + function ($log, $http, $loc) { | ||
| 37 | + var self = this; | ||
| 38 | + self.deviceData = []; | ||
| 39 | + var url = buildUrl($loc) + urlSuffix; | ||
| 40 | + $log.log(url); | ||
| 41 | + | ||
| 42 | + $http.get(url).then( | ||
| 43 | + //success | ||
| 44 | + function (response) { | ||
| 45 | + self.deviceData = response.data.devices; | ||
| 46 | + }, | ||
| 47 | + //failure | ||
| 48 | + function (response) { | ||
| 49 | + $log.warn('Failed to get device data ', response.status); | ||
| 50 | + } | ||
| 51 | + ); | ||
| 52 | + | ||
| 53 | + $log.log('OvDeviceCtrl has been created'); | ||
| 54 | + }]); | ||
| 55 | +}()); |
| 1 | +/* | ||
| 2 | + * Copyright 2015 Open Networking Laboratory | ||
| 3 | + * | ||
| 4 | + * Licensed under the Apache License, Version 2.0 (the "License"); | ||
| 5 | + * you may not use this file except in compliance with the License. | ||
| 6 | + * You may obtain a copy of the License at | ||
| 7 | + * | ||
| 8 | + * http://www.apache.org/licenses/LICENSE-2.0 | ||
| 9 | + * | ||
| 10 | + * Unless required by applicable law or agreed to in writing, software | ||
| 11 | + * distributed under the License is distributed on an "AS IS" BASIS, | ||
| 12 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
| 13 | + * See the License for the specific language governing permissions and | ||
| 14 | + * limitations under the License. | ||
| 15 | + */ | ||
| 16 | + | ||
| 17 | +/* | ||
| 18 | + ONOS GUI -- Device Controller - Unit Tests | ||
| 19 | + | ||
| 20 | + @author Simon Hunt | ||
| 21 | + */ | ||
| 22 | +describe('Controller: OvDeviceCtrl', function () { | ||
| 23 | + // instantiate the Device module | ||
| 24 | + beforeEach(module('ovDevice')); | ||
| 25 | + | ||
| 26 | + var $log, $controller, ctrl, $mockHttp; | ||
| 27 | + | ||
| 28 | + var fakeData = { | ||
| 29 | + "devices": [ | ||
| 30 | + { | ||
| 31 | + "id": "of:0000000000000001", | ||
| 32 | + "available": true, | ||
| 33 | + "role": "MASTER", | ||
| 34 | + "mfr": "Nicira, Inc.", | ||
| 35 | + "hw": "Open vSwitch", | ||
| 36 | + "sw": "2.0.1", | ||
| 37 | + "serial": "None", | ||
| 38 | + "annotations": { | ||
| 39 | + "protocol": "OF_10" | ||
| 40 | + } | ||
| 41 | + }, | ||
| 42 | + { | ||
| 43 | + "id": "of:0000000000000004", | ||
| 44 | + "available": true, | ||
| 45 | + "role": "MASTER", | ||
| 46 | + "mfr": "Nicira, Inc.", | ||
| 47 | + "hw": "Open vSwitch", | ||
| 48 | + "sw": "2.0.1", | ||
| 49 | + "serial": "None", | ||
| 50 | + "annotations": { | ||
| 51 | + "protocol": "OF_10" | ||
| 52 | + } | ||
| 53 | + }] | ||
| 54 | + }; | ||
| 55 | + | ||
| 56 | + // we need an instance of the controller | ||
| 57 | + beforeEach(inject(function(_$log_, _$controller_, $httpBackend) { | ||
| 58 | + $log = _$log_; | ||
| 59 | + $controller = _$controller_; | ||
| 60 | + $mockHttp = $httpBackend; | ||
| 61 | + | ||
| 62 | + $mockHttp.whenGET(/devices/).respond(fakeData); | ||
| 63 | + | ||
| 64 | + })); | ||
| 65 | + | ||
| 66 | + //afterEach($mockHttp.resetExpectations); | ||
| 67 | + | ||
| 68 | + it('should be an empty array', function () { | ||
| 69 | + ctrl = $controller('OvDeviceCtrl'); | ||
| 70 | + expect(ctrl.deviceData).toEqual([]); | ||
| 71 | + }); | ||
| 72 | + | ||
| 73 | + it('should have data in it', function () { | ||
| 74 | + ctrl = $controller('OvDeviceCtrl'); | ||
| 75 | + $mockHttp.flush(); | ||
| 76 | + expect(ctrl.deviceData).toEqual(fakeData.devices); | ||
| 77 | + }) | ||
| 78 | +}); |
| 1 | +{ | ||
| 2 | + "devices": [ | ||
| 3 | + { | ||
| 4 | + "id": "of:0000000000000001", | ||
| 5 | + "available": true, | ||
| 6 | + "role": "MASTER", | ||
| 7 | + "mfr": "Nicira, Inc.", | ||
| 8 | + "hw": "Open vSwitch", | ||
| 9 | + "sw": "2.0.1", | ||
| 10 | + "serial": "None", | ||
| 11 | + "annotations": { | ||
| 12 | + "protocol": "OF_10" | ||
| 13 | + } | ||
| 14 | + }, | ||
| 15 | + { | ||
| 16 | + "id": "of:0000000000000004", | ||
| 17 | + "available": true, | ||
| 18 | + "role": "MASTER", | ||
| 19 | + "mfr": "Nicira, Inc.", | ||
| 20 | + "hw": "Open vSwitch", | ||
| 21 | + "sw": "2.0.1", | ||
| 22 | + "serial": "None", | ||
| 23 | + "annotations": { | ||
| 24 | + "protocol": "OF_10" | ||
| 25 | + } | ||
| 26 | + }, | ||
| 27 | + { | ||
| 28 | + "id": "of:0000000000000005", | ||
| 29 | + "available": true, | ||
| 30 | + "role": "MASTER", | ||
| 31 | + "mfr": "Nicira, Inc.", | ||
| 32 | + "hw": "Open vSwitch", | ||
| 33 | + "sw": "2.0.1", | ||
| 34 | + "serial": "None", | ||
| 35 | + "annotations": { | ||
| 36 | + "protocol": "OF_10" | ||
| 37 | + } | ||
| 38 | + }, | ||
| 39 | + { | ||
| 40 | + "id": "of:0000000000000002", | ||
| 41 | + "available": true, | ||
| 42 | + "role": "MASTER", | ||
| 43 | + "mfr": "Nicira, Inc.", | ||
| 44 | + "hw": "Open vSwitch", | ||
| 45 | + "sw": "2.0.1", | ||
| 46 | + "serial": "None", | ||
| 47 | + "annotations": { | ||
| 48 | + "protocol": "OF_10" | ||
| 49 | + } | ||
| 50 | + }, | ||
| 51 | + { | ||
| 52 | + "id": "of:0000000000000003", | ||
| 53 | + "available": true, | ||
| 54 | + "role": "MASTER", | ||
| 55 | + "mfr": "Nicira, Inc.", | ||
| 56 | + "hw": "Open vSwitch", | ||
| 57 | + "sw": "2.0.1", | ||
| 58 | + "serial": "None", | ||
| 59 | + "annotations": { | ||
| 60 | + "protocol": "OF_10" | ||
| 61 | + } | ||
| 62 | + }, | ||
| 63 | + { | ||
| 64 | + "id": "of:0000000000000006", | ||
| 65 | + "available": true, | ||
| 66 | + "role": "MASTER", | ||
| 67 | + "mfr": "Nicira, Inc.", | ||
| 68 | + "hw": "Open vSwitch", | ||
| 69 | + "sw": "2.0.1", | ||
| 70 | + "serial": "None", | ||
| 71 | + "annotations": { | ||
| 72 | + "protocol": "OF_10" | ||
| 73 | + } | ||
| 74 | + }, | ||
| 75 | + { | ||
| 76 | + "id": "of:0000000000000007", | ||
| 77 | + "available": true, | ||
| 78 | + "role": "MASTER", | ||
| 79 | + "mfr": "Nicira, Inc.", | ||
| 80 | + "hw": "Open vSwitch", | ||
| 81 | + "sw": "2.0.1", | ||
| 82 | + "serial": "None", | ||
| 83 | + "annotations": { | ||
| 84 | + "protocol": "OF_10" | ||
| 85 | + } | ||
| 86 | + } | ||
| 87 | + ] | ||
| 88 | +} | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
-
Please register or login to post a comment