stack_service_test.js 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295
  1. /**
  2. * Licensed to the Apache Software Foundation (ASF) under one
  3. * or more contributor license agreements. See the NOTICE file
  4. * distributed with this work for additional information
  5. * regarding copyright ownership. The ASF licenses this file
  6. * to you under the Apache License, Version 2.0 (the
  7. * "License"); you may not use this file except in compliance
  8. * with the License. You may obtain a copy of the License at
  9. *
  10. * http://www.apache.org/licenses/LICENSE-2.0
  11. *
  12. * Unless required by applicable law or agreed to in writing, software
  13. * distributed under the License is distributed on an "AS IS" BASIS,
  14. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  15. * See the License for the specific language governing permissions and
  16. * limitations under the License.
  17. */
  18. var App = require('app');
  19. require('models/stack_service');
  20. describe('App.StackService', function () {
  21. App.store.load(App.StackService, {
  22. id: 'S1'
  23. });
  24. var ss = App.StackService.find('S1');
  25. ss.reopen({
  26. serviceComponents: []
  27. });
  28. describe('#isDFS', function () {
  29. it('service name is "SERVICE"', function () {
  30. ss.set('serviceName', 'SERVICE');
  31. ss.propertyDidChange('isDFS');
  32. expect(ss.get('isDFS')).to.be.false;
  33. });
  34. it('service name is "HDFS"', function () {
  35. ss.set('serviceName', 'HDFS');
  36. ss.propertyDidChange('isDFS');
  37. expect(ss.get('isDFS')).to.be.true;
  38. });
  39. it('service name is "GLUSTERFS"', function () {
  40. ss.set('serviceName', 'GLUSTERFS');
  41. ss.propertyDidChange('isDFS');
  42. expect(ss.get('isDFS')).to.be.true;
  43. });
  44. });
  45. describe('#isPrimaryDFS', function () {
  46. it('service name is "SERVICE"', function () {
  47. ss.set('serviceName', 'SERVICE');
  48. ss.propertyDidChange('isPrimaryDFS');
  49. expect(ss.get('isPrimaryDFS')).to.be.false;
  50. });
  51. it('service name is "HDFS"', function () {
  52. ss.set('serviceName', 'HDFS');
  53. ss.propertyDidChange('isPrimaryDFS');
  54. expect(ss.get('isPrimaryDFS')).to.be.true;
  55. });
  56. });
  57. describe('#configTypesRendered', function () {
  58. ss.set('configTypes', {
  59. 'core-site': {},
  60. 'hdfs-site': {},
  61. 'oozie-site': {}
  62. });
  63. it('service name is "SERVICE"', function () {
  64. ss.set('serviceName', 'SERVICE');
  65. ss.propertyDidChange('configTypesRendered');
  66. expect(ss.get('configTypesRendered')).to.eql({'core-site': {},'hdfs-site': {}, 'oozie-site': {}});
  67. });
  68. it('service name is "GLUSTERFS"', function () {
  69. ss.set('serviceName', 'GLUSTERFS');
  70. ss.propertyDidChange('configTypesRendered');
  71. expect(ss.get('configTypesRendered')).to.eql({'core-site': {},'hdfs-site': {}, 'oozie-site': {}});
  72. });
  73. it('service name is "HDFS"', function () {
  74. ss.set('serviceName', 'HDFS');
  75. ss.propertyDidChange('configTypesRendered');
  76. expect(ss.get('configTypesRendered')).to.eql({'core-site': {}, 'hdfs-site': {}, 'oozie-site': {}});
  77. });
  78. it('service name is "FALCON"', function () {
  79. ss.set('serviceName', 'FALCON');
  80. ss.propertyDidChange('configTypesRendered');
  81. expect(ss.get('configTypesRendered')).to.eql({'core-site': {}, 'hdfs-site': {}});
  82. });
  83. });
  84. describe('#displayNameOnSelectServicePage', function () {
  85. it('No coSelectedServices', function () {
  86. ss.set('serviceName', 'HDFS');
  87. ss.set('displayName', 'HDFS');
  88. ss.propertyDidChange('displayNameOnSelectServicePage');
  89. expect(ss.get('displayNameOnSelectServicePage')).to.equal('HDFS');
  90. });
  91. it('Present coSelectedServices', function () {
  92. ss.set('serviceName', 'YARN');
  93. ss.set('displayName', 'YARN');
  94. ss.propertyDidChange('displayNameOnSelectServicePage');
  95. expect(ss.get('displayNameOnSelectServicePage')).to.equal('YARN + MapReduce2');
  96. });
  97. });
  98. describe('#isHiddenOnSelectServicePage', function () {
  99. var testCases = [
  100. {
  101. serviceName: 'HDFS',
  102. isInstallable: true,
  103. result: false
  104. },
  105. {
  106. serviceName: 'MAPREDUCE2',
  107. isInstallable: true,
  108. result: true
  109. },
  110. {
  111. serviceName: 'KERBEROS',
  112. isInstallable: false,
  113. result: true
  114. }
  115. ];
  116. testCases.forEach(function (test) {
  117. it('service name - ' + test.serviceName, function () {
  118. ss.set('serviceName', test.serviceName);
  119. ss.set('isInstallable', test.isInstallable);
  120. ss.propertyDidChange('isHiddenOnSelectServicePage');
  121. expect(ss.get('isHiddenOnSelectServicePage')).to.equal(test.result);
  122. });
  123. });
  124. });
  125. describe('#isMonitoringService', function () {
  126. var testCases = [
  127. {
  128. serviceName: 'HDFS',
  129. result: false
  130. },
  131. {
  132. serviceName: 'GANGLIA',
  133. result: true
  134. }
  135. ];
  136. testCases.forEach(function (test) {
  137. it('service name - ' + test.serviceName, function () {
  138. ss.set('serviceName', test.serviceName);
  139. ss.propertyDidChange('isMonitoringService');
  140. expect(ss.get('isMonitoringService')).to.equal(test.result);
  141. });
  142. });
  143. });
  144. describe('#hasClient', function () {
  145. it('No client serviceComponents', function () {
  146. ss.set('serviceComponents', []);
  147. ss.propertyDidChange('hasClient');
  148. expect(ss.get('hasClient')).to.be.false;
  149. });
  150. it('Has client serviceComponents', function () {
  151. ss.set('serviceComponents', [Em.Object.create({isClient: true})]);
  152. ss.propertyDidChange('hasClient');
  153. expect(ss.get('hasClient')).to.be.true;
  154. });
  155. });
  156. describe('#hasMaster', function () {
  157. it('No master serviceComponents', function () {
  158. ss.set('serviceComponents', []);
  159. ss.propertyDidChange('hasMaster');
  160. expect(ss.get('hasMaster')).to.be.false;
  161. });
  162. it('Has master serviceComponents', function () {
  163. ss.set('serviceComponents', [Em.Object.create({isMaster: true})]);
  164. ss.propertyDidChange('hasMaster');
  165. expect(ss.get('hasMaster')).to.be.true;
  166. });
  167. });
  168. describe('#hasSlave', function () {
  169. it('No slave serviceComponents', function () {
  170. ss.set('serviceComponents', []);
  171. ss.propertyDidChange('hasSlave');
  172. expect(ss.get('hasSlave')).to.be.false;
  173. });
  174. it('Has slave serviceComponents', function () {
  175. ss.set('serviceComponents', [Em.Object.create({isSlave: true})]);
  176. ss.propertyDidChange('hasSlave');
  177. expect(ss.get('hasSlave')).to.be.true;
  178. });
  179. });
  180. describe('#hasNonMastersWithCustomAssignment', function () {
  181. it('No serviceComponents', function () {
  182. ss.set('serviceComponents', []);
  183. ss.propertyDidChange('hasNonMastersWithCustomAssignment');
  184. expect(ss.get('hasNonMastersWithCustomAssignment')).to.be.false;
  185. });
  186. it('All non-master serviceComponents are required on all hosts', function () {
  187. ss.set('serviceComponents', [Em.Object.create({isMaster: true}), Em.Object.create({isSlave: true, cardinality: 'ALL'}), Em.Object.create({isClient: true, cardinality: 'ALL'})]);
  188. ss.propertyDidChange('hasNonMastersWithCustomAssignment');
  189. expect(ss.get('hasNonMastersWithCustomAssignment')).to.be.false;
  190. });
  191. it('Has non-master serviceComponents not required on all hosts', function () {
  192. ss.set('serviceComponents', [Em.Object.create({isSlave: true}), Em.Object.create({isClient: true})]);
  193. ss.propertyDidChange('hasNonMastersWithCustomAssignment');
  194. expect(ss.get('hasNonMastersWithCustomAssignment')).to.be.true;
  195. });
  196. });
  197. describe('#isClientOnlyService', function () {
  198. it('Has not only client serviceComponents', function () {
  199. ss.set('serviceComponents', [Em.Object.create({isSlave: true}), Em.Object.create({isClient: true})]);
  200. ss.propertyDidChange('isClientOnlyService');
  201. expect(ss.get('isClientOnlyService')).to.be.false;
  202. });
  203. it('Has only client serviceComponents', function () {
  204. ss.set('serviceComponents', [Em.Object.create({isClient: true})]);
  205. ss.propertyDidChange('isClientOnlyService');
  206. expect(ss.get('isClientOnlyService')).to.be.true;
  207. });
  208. });
  209. describe('#isNoConfigTypes', function () {
  210. it('configTypes is null', function () {
  211. ss.set('configTypes', null);
  212. ss.propertyDidChange('isNoConfigTypes');
  213. expect(ss.get('isNoConfigTypes')).to.be.true;
  214. });
  215. it('configTypes is empty', function () {
  216. ss.set('configTypes', {});
  217. ss.propertyDidChange('isNoConfigTypes');
  218. expect(ss.get('isNoConfigTypes')).to.be.true;
  219. });
  220. it('configTypes is correct', function () {
  221. ss.set('configTypes', {'key': {}});
  222. ss.propertyDidChange('isNoConfigTypes');
  223. expect(ss.get('isNoConfigTypes')).to.be.false;
  224. });
  225. });
  226. describe('#customReviewHandler', function () {
  227. it('service name is HDFS', function () {
  228. ss.set('serviceName', 'HDFS');
  229. ss.propertyDidChange('customReviewHandler');
  230. expect(ss.get('customReviewHandler')).to.be.undefined;
  231. });
  232. it('service name is HIVE', function () {
  233. ss.set('serviceName', 'HIVE');
  234. ss.propertyDidChange('customReviewHandler');
  235. expect(ss.get('customReviewHandler')).to.eql({
  236. "Database": "loadHiveDbValue"
  237. });
  238. });
  239. });
  240. describe('#configCategories', function () {
  241. it('HDFS service with no serviceComponents', function () {
  242. ss.set('serviceComponents', []);
  243. ss.set('serviceName', 'HDFS');
  244. ss.propertyDidChange('configCategories');
  245. expect(ss.get('configCategories').mapProperty('name')).to.eql([
  246. "General",
  247. "Advanced",
  248. "RangerSettings",
  249. "HDFSAuditSettings",
  250. "RepositoryConfigs",
  251. "SSLRangerSettings",
  252. "Advanced key",
  253. "Custom key"
  254. ]);
  255. });
  256. it('HDFS service with DATANODE serviceComponents', function () {
  257. ss.set('serviceComponents', [Em.Object.create({componentName: 'DATANODE'})]);
  258. ss.set('serviceName', 'HDFS');
  259. ss.propertyDidChange('configCategories');
  260. expect(ss.get('configCategories').mapProperty('name')).to.eql([
  261. "DATANODE",
  262. "General",
  263. "Advanced",
  264. "RangerSettings",
  265. "HDFSAuditSettings",
  266. "RepositoryConfigs",
  267. "SSLRangerSettings",
  268. "Advanced key",
  269. "Custom key"]);
  270. });
  271. });
  272. });