stack_service_test.js 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291
  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: 'NAGIOS',
  133. result: true
  134. },
  135. {
  136. serviceName: 'GANGLIA',
  137. result: true
  138. }
  139. ];
  140. testCases.forEach(function (test) {
  141. it('service name - ' + test.serviceName, function () {
  142. ss.set('serviceName', test.serviceName);
  143. ss.propertyDidChange('isMonitoringService');
  144. expect(ss.get('isMonitoringService')).to.equal(test.result);
  145. });
  146. });
  147. });
  148. describe('#hasClient', function () {
  149. it('No client serviceComponents', function () {
  150. ss.set('serviceComponents', []);
  151. ss.propertyDidChange('hasClient');
  152. expect(ss.get('hasClient')).to.be.false;
  153. });
  154. it('Has client serviceComponents', function () {
  155. ss.set('serviceComponents', [Em.Object.create({isClient: true})]);
  156. ss.propertyDidChange('hasClient');
  157. expect(ss.get('hasClient')).to.be.true;
  158. });
  159. });
  160. describe('#hasMaster', function () {
  161. it('No master serviceComponents', function () {
  162. ss.set('serviceComponents', []);
  163. ss.propertyDidChange('hasMaster');
  164. expect(ss.get('hasMaster')).to.be.false;
  165. });
  166. it('Has master serviceComponents', function () {
  167. ss.set('serviceComponents', [Em.Object.create({isMaster: true})]);
  168. ss.propertyDidChange('hasMaster');
  169. expect(ss.get('hasMaster')).to.be.true;
  170. });
  171. });
  172. describe('#hasSlave', function () {
  173. it('No slave serviceComponents', function () {
  174. ss.set('serviceComponents', []);
  175. ss.propertyDidChange('hasSlave');
  176. expect(ss.get('hasSlave')).to.be.false;
  177. });
  178. it('Has slave serviceComponents', function () {
  179. ss.set('serviceComponents', [Em.Object.create({isSlave: true})]);
  180. ss.propertyDidChange('hasSlave');
  181. expect(ss.get('hasSlave')).to.be.true;
  182. });
  183. });
  184. describe('#hasNonMastersWithCustomAssignment', function () {
  185. it('No serviceComponents', function () {
  186. ss.set('serviceComponents', []);
  187. ss.propertyDidChange('hasNonMastersWithCustomAssignment');
  188. expect(ss.get('hasNonMastersWithCustomAssignment')).to.be.false;
  189. });
  190. it('All non-master serviceComponents are required on all hosts', function () {
  191. ss.set('serviceComponents', [Em.Object.create({isMaster: true}), Em.Object.create({isSlave: true, cardinality: 'ALL'}), Em.Object.create({isClient: true, cardinality: 'ALL'})]);
  192. ss.propertyDidChange('hasNonMastersWithCustomAssignment');
  193. expect(ss.get('hasNonMastersWithCustomAssignment')).to.be.false;
  194. });
  195. it('Has non-master serviceComponents not required on all hosts', function () {
  196. ss.set('serviceComponents', [Em.Object.create({isSlave: true}), Em.Object.create({isClient: true})]);
  197. ss.propertyDidChange('hasNonMastersWithCustomAssignment');
  198. expect(ss.get('hasNonMastersWithCustomAssignment')).to.be.true;
  199. });
  200. });
  201. describe('#isClientOnlyService', function () {
  202. it('Has not only client serviceComponents', function () {
  203. ss.set('serviceComponents', [Em.Object.create({isSlave: true}), Em.Object.create({isClient: true})]);
  204. ss.propertyDidChange('isClientOnlyService');
  205. expect(ss.get('isClientOnlyService')).to.be.false;
  206. });
  207. it('Has only client serviceComponents', function () {
  208. ss.set('serviceComponents', [Em.Object.create({isClient: true})]);
  209. ss.propertyDidChange('isClientOnlyService');
  210. expect(ss.get('isClientOnlyService')).to.be.true;
  211. });
  212. });
  213. describe('#isNoConfigTypes', function () {
  214. it('configTypes is null', function () {
  215. ss.set('configTypes', null);
  216. ss.propertyDidChange('isNoConfigTypes');
  217. expect(ss.get('isNoConfigTypes')).to.be.true;
  218. });
  219. it('configTypes is empty', function () {
  220. ss.set('configTypes', {});
  221. ss.propertyDidChange('isNoConfigTypes');
  222. expect(ss.get('isNoConfigTypes')).to.be.true;
  223. });
  224. it('configTypes is correct', function () {
  225. ss.set('configTypes', {'key': {}});
  226. ss.propertyDidChange('isNoConfigTypes');
  227. expect(ss.get('isNoConfigTypes')).to.be.false;
  228. });
  229. });
  230. describe('#customReviewHandler', function () {
  231. it('service name is HDFS', function () {
  232. ss.set('serviceName', 'HDFS');
  233. ss.propertyDidChange('customReviewHandler');
  234. expect(ss.get('customReviewHandler')).to.be.undefined;
  235. });
  236. it('service name is HIVE', function () {
  237. ss.set('serviceName', 'HIVE');
  238. ss.propertyDidChange('customReviewHandler');
  239. expect(ss.get('customReviewHandler')).to.eql({
  240. "Database": "loadHiveDbValue"
  241. });
  242. });
  243. });
  244. describe('#configCategories', function () {
  245. it('HDFS service with no serviceComponents', function () {
  246. ss.set('serviceComponents', []);
  247. ss.set('serviceName', 'HDFS');
  248. ss.propertyDidChange('configCategories');
  249. expect(ss.get('configCategories').mapProperty('name')).to.eql([
  250. "General",
  251. "Advanced",
  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. "Advanced key",
  265. "Custom key"]);
  266. });
  267. });
  268. });