MuranoCLI 2.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (151) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +28 -0
  3. data/.rspec +2 -0
  4. data/.travis.yml +21 -0
  5. data/Gemfile +27 -0
  6. data/LICENSE.txt +19 -0
  7. data/MuranoCLI.gemspec +50 -0
  8. data/MuranoCLI.iss +50 -0
  9. data/README.markdown +208 -0
  10. data/Rakefile +188 -0
  11. data/TODO.taskpaper +122 -0
  12. data/bin/mr +8 -0
  13. data/bin/murano +84 -0
  14. data/docs/demo.md +109 -0
  15. data/lib/MrMurano/Account.rb +211 -0
  16. data/lib/MrMurano/Config-Migrate.rb +47 -0
  17. data/lib/MrMurano/Config.rb +286 -0
  18. data/lib/MrMurano/Mock.rb +63 -0
  19. data/lib/MrMurano/Product-1P-Device.rb +145 -0
  20. data/lib/MrMurano/Product-Resources.rb +195 -0
  21. data/lib/MrMurano/Product.rb +358 -0
  22. data/lib/MrMurano/ProjectFile.rb +349 -0
  23. data/lib/MrMurano/Solution-Cors.rb +46 -0
  24. data/lib/MrMurano/Solution-Endpoint.rb +177 -0
  25. data/lib/MrMurano/Solution-File.rb +150 -0
  26. data/lib/MrMurano/Solution-ServiceConfig.rb +140 -0
  27. data/lib/MrMurano/Solution-Services.rb +326 -0
  28. data/lib/MrMurano/Solution-Users.rb +129 -0
  29. data/lib/MrMurano/Solution.rb +59 -0
  30. data/lib/MrMurano/SubCmdGroupContext.rb +49 -0
  31. data/lib/MrMurano/SyncUpDown.rb +565 -0
  32. data/lib/MrMurano/commands/assign.rb +57 -0
  33. data/lib/MrMurano/commands/businessList.rb +45 -0
  34. data/lib/MrMurano/commands/completion.rb +152 -0
  35. data/lib/MrMurano/commands/config.rb +67 -0
  36. data/lib/MrMurano/commands/content.rb +130 -0
  37. data/lib/MrMurano/commands/cors.rb +30 -0
  38. data/lib/MrMurano/commands/domain.rb +17 -0
  39. data/lib/MrMurano/commands/gb.rb +33 -0
  40. data/lib/MrMurano/commands/init.rb +138 -0
  41. data/lib/MrMurano/commands/keystore.rb +157 -0
  42. data/lib/MrMurano/commands/logs.rb +78 -0
  43. data/lib/MrMurano/commands/mock.rb +63 -0
  44. data/lib/MrMurano/commands/password.rb +88 -0
  45. data/lib/MrMurano/commands/postgresql.rb +41 -0
  46. data/lib/MrMurano/commands/product.rb +14 -0
  47. data/lib/MrMurano/commands/productCreate.rb +39 -0
  48. data/lib/MrMurano/commands/productDelete.rb +33 -0
  49. data/lib/MrMurano/commands/productDevice.rb +84 -0
  50. data/lib/MrMurano/commands/productDeviceIdCmds.rb +86 -0
  51. data/lib/MrMurano/commands/productList.rb +45 -0
  52. data/lib/MrMurano/commands/productWrite.rb +27 -0
  53. data/lib/MrMurano/commands/show.rb +80 -0
  54. data/lib/MrMurano/commands/solution.rb +14 -0
  55. data/lib/MrMurano/commands/solutionCreate.rb +39 -0
  56. data/lib/MrMurano/commands/solutionDelete.rb +34 -0
  57. data/lib/MrMurano/commands/solutionList.rb +45 -0
  58. data/lib/MrMurano/commands/status.rb +92 -0
  59. data/lib/MrMurano/commands/sync.rb +60 -0
  60. data/lib/MrMurano/commands/timeseries.rb +115 -0
  61. data/lib/MrMurano/commands/tsdb.rb +271 -0
  62. data/lib/MrMurano/commands/usage.rb +23 -0
  63. data/lib/MrMurano/commands/zshcomplete.erb +112 -0
  64. data/lib/MrMurano/commands.rb +32 -0
  65. data/lib/MrMurano/hash.rb +20 -0
  66. data/lib/MrMurano/http.rb +153 -0
  67. data/lib/MrMurano/makePretty.rb +75 -0
  68. data/lib/MrMurano/schema/pf-v1.0.0.yaml +114 -0
  69. data/lib/MrMurano/schema/sf-v0.2.0.yaml +77 -0
  70. data/lib/MrMurano/schema/sf-v0.3.0.yaml +78 -0
  71. data/lib/MrMurano/template/mock.erb +9 -0
  72. data/lib/MrMurano/template/projectFile.murano.erb +81 -0
  73. data/lib/MrMurano/verbosing.rb +99 -0
  74. data/lib/MrMurano/version.rb +4 -0
  75. data/lib/MrMurano.rb +20 -0
  76. data/spec/Account-Passwords_spec.rb +242 -0
  77. data/spec/Account_spec.rb +272 -0
  78. data/spec/ConfigFile_spec.rb +50 -0
  79. data/spec/ConfigMigrate_spec.rb +89 -0
  80. data/spec/Config_spec.rb +409 -0
  81. data/spec/Http_spec.rb +204 -0
  82. data/spec/MakePretties_spec.rb +118 -0
  83. data/spec/Mock_spec.rb +53 -0
  84. data/spec/ProductBase_spec.rb +113 -0
  85. data/spec/ProductContent_spec.rb +162 -0
  86. data/spec/ProductResources_spec.rb +329 -0
  87. data/spec/Product_1P_Device_spec.rb +202 -0
  88. data/spec/Product_1P_RPC_spec.rb +175 -0
  89. data/spec/Product_spec.rb +153 -0
  90. data/spec/ProjectFile_spec.rb +324 -0
  91. data/spec/Solution-Cors_spec.rb +164 -0
  92. data/spec/Solution-Endpoint_spec.rb +581 -0
  93. data/spec/Solution-File_spec.rb +212 -0
  94. data/spec/Solution-ServiceConfig_spec.rb +202 -0
  95. data/spec/Solution-ServiceDevice_spec.rb +176 -0
  96. data/spec/Solution-ServiceEventHandler_spec.rb +385 -0
  97. data/spec/Solution-ServiceModules_spec.rb +465 -0
  98. data/spec/Solution-UsersRoles_spec.rb +207 -0
  99. data/spec/Solution_spec.rb +92 -0
  100. data/spec/SyncRoot_spec.rb +83 -0
  101. data/spec/SyncUpDown_spec.rb +495 -0
  102. data/spec/Verbosing_spec.rb +279 -0
  103. data/spec/_workspace.rb +27 -0
  104. data/spec/cmd_assign_spec.rb +51 -0
  105. data/spec/cmd_business_spec.rb +59 -0
  106. data/spec/cmd_common.rb +72 -0
  107. data/spec/cmd_config_spec.rb +68 -0
  108. data/spec/cmd_content_spec.rb +71 -0
  109. data/spec/cmd_cors_spec.rb +50 -0
  110. data/spec/cmd_device_spec.rb +96 -0
  111. data/spec/cmd_domain_spec.rb +32 -0
  112. data/spec/cmd_init_spec.rb +30 -0
  113. data/spec/cmd_keystore_spec.rb +97 -0
  114. data/spec/cmd_password_spec.rb +62 -0
  115. data/spec/cmd_status_spec.rb +239 -0
  116. data/spec/cmd_syncdown_spec.rb +86 -0
  117. data/spec/cmd_syncup_spec.rb +62 -0
  118. data/spec/cmd_usage_spec.rb +36 -0
  119. data/spec/fixtures/.mrmuranorc +9 -0
  120. data/spec/fixtures/ProjectFiles/invalid.yaml +9 -0
  121. data/spec/fixtures/ProjectFiles/only_meta.yaml +24 -0
  122. data/spec/fixtures/ProjectFiles/with_routes.yaml +27 -0
  123. data/spec/fixtures/SolutionFiles/0.2.0.json +20 -0
  124. data/spec/fixtures/SolutionFiles/0.2.0_invalid.json +18 -0
  125. data/spec/fixtures/SolutionFiles/0.2.json +21 -0
  126. data/spec/fixtures/SolutionFiles/0.3.0.json +20 -0
  127. data/spec/fixtures/SolutionFiles/0.3.0_invalid.json +19 -0
  128. data/spec/fixtures/SolutionFiles/0.3.json +20 -0
  129. data/spec/fixtures/SolutionFiles/basic.json +20 -0
  130. data/spec/fixtures/SolutionFiles/secret.json +6 -0
  131. data/spec/fixtures/configfile +9 -0
  132. data/spec/fixtures/dumped_config +42 -0
  133. data/spec/fixtures/mrmuranorc_deleted_bob +8 -0
  134. data/spec/fixtures/mrmuranorc_tool_bob +3 -0
  135. data/spec/fixtures/product_spec_files/example.exoline.spec.yaml +116 -0
  136. data/spec/fixtures/product_spec_files/example.murano.spec.yaml +14 -0
  137. data/spec/fixtures/product_spec_files/gwe.exoline.spec.yaml +21 -0
  138. data/spec/fixtures/product_spec_files/gwe.murano.spec.yaml +16 -0
  139. data/spec/fixtures/product_spec_files/lightbulb-no-state.yaml +11 -0
  140. data/spec/fixtures/product_spec_files/lightbulb.yaml +14 -0
  141. data/spec/fixtures/roles-three.yaml +11 -0
  142. data/spec/fixtures/syncable_content/assets/icon.png +0 -0
  143. data/spec/fixtures/syncable_content/assets/index.html +0 -0
  144. data/spec/fixtures/syncable_content/assets/js/script.js +0 -0
  145. data/spec/fixtures/syncable_content/modules/table_util.lua +58 -0
  146. data/spec/fixtures/syncable_content/routes/manyRoutes.lua +11 -0
  147. data/spec/fixtures/syncable_content/routes/singleRoute.lua +5 -0
  148. data/spec/fixtures/syncable_content/services/devdata.lua +18 -0
  149. data/spec/fixtures/syncable_content/services/timers.lua +4 -0
  150. data/spec/spec_helper.rb +119 -0
  151. metadata +498 -0
@@ -0,0 +1,62 @@
1
+ require 'fileutils'
2
+ require 'open3'
3
+ require 'pathname'
4
+ require 'cmd_common'
5
+
6
+ RSpec.describe 'murano password', :cmd do
7
+ include_context "CI_CMD"
8
+
9
+ it "Lists when no file" do
10
+ out, err, status = Open3.capture3(capcmd('murano', 'password', 'list'))
11
+ expect(err).to eq('')
12
+ olines = out.lines
13
+ expect(olines[0]).to match(/^(\+-+){2}\+$/)
14
+ expect(olines[1]).to match(/^\| Host\s+\| Username\s+\|$/)
15
+ expect(olines[2]).to match(/^(\+-+){2}\+$/)
16
+ expect(status.exitstatus).to eq(0)
17
+ end
18
+
19
+ it "sets a password" do
20
+ out, err, status = Open3.capture3(capcmd('murano', 'password', 'set', 'bob@bob.bob', 'an.API.host.i', '--password', 'bad'))
21
+ expect(err).to eq('')
22
+ expect(out).to eq('')
23
+ expect(status.exitstatus).to eq(0)
24
+
25
+ out, err, status = Open3.capture3(capcmd('murano', 'password', 'list'))
26
+ expect(err).to eq('')
27
+ olines = out.lines
28
+ expect(olines[0]).to match(/^(\+-+){2}\+$/)
29
+ expect(olines[1]).to match(/^\| Host\s+\| Username\s+\|$/)
30
+ expect(olines[2]).to match(/^(\+-+){2}\+$/)
31
+ expect(olines[3]).to match(/^\| an.API.host.i\s+\| bob@bob\.bob\s+\|$/)
32
+ expect(olines[4]).to match(/^(\+-+){2}\+$/)
33
+ expect(status.exitstatus).to eq(0)
34
+ end
35
+
36
+ it "deletes a password" do
37
+ File.open(File.join(ENV['HOME'], '.murano', 'passwords'), 'w') do |io|
38
+ io << "---\n"
39
+ io << "an.API.host.i:\n"
40
+ io << " bob@bob.bob: badpassword\n"
41
+ io << " rich@er.u: notbetter\n"
42
+ end
43
+ out, err, status = Open3.capture3(capcmd('murano', 'password', 'delete', 'rich@er.u', 'an.API.host.i'))
44
+ expect(err).to eq('')
45
+ expect(out).to eq('')
46
+ expect(status.exitstatus).to eq(0)
47
+
48
+
49
+ out, err, status = Open3.capture3(capcmd('murano', 'password', 'list'))
50
+ expect(err).to eq('')
51
+ olines = out.lines
52
+ expect(olines[0]).to match(/^(\+-+){2}\+$/)
53
+ expect(olines[1]).to match(/^\| Host\s+\| Username\s+\|$/)
54
+ expect(olines[2]).to match(/^(\+-+){2}\+$/)
55
+ expect(olines[3]).to match(/^\| an.API.host.i\s+\| bob@bob\.bob\s+\|$/)
56
+ expect(olines[4]).to match(/^(\+-+){2}\+$/)
57
+ expect(status.exitstatus).to eq(0)
58
+ end
59
+
60
+ end
61
+
62
+ # vim: set ai et sw=2 ts=2 :
@@ -0,0 +1,239 @@
1
+ require 'fileutils'
2
+ require 'open3'
3
+ require 'pathname'
4
+ require 'json'
5
+ require 'cmd_common'
6
+
7
+ RSpec.describe 'murano status', :cmd, :needs_password do
8
+ include_context "CI_CMD"
9
+
10
+ before(:example) do
11
+ @project_name = rname('statusTest')
12
+ out, err, status = Open3.capture3(capcmd('murano', 'solution', 'create', @project_name, '--save'))
13
+ expect(err).to eq('')
14
+ expect(out.chomp).to match(/^[a-zA-Z0-9]+$/)
15
+ expect(status.exitstatus).to eq(0)
16
+
17
+ out, err, status = Open3.capture3(capcmd('murano', 'product', 'create', @project_name, '--save'))
18
+ expect(err).to eq('')
19
+ expect(out.chomp).to match(/^[a-zA-Z0-9]+$/)
20
+ expect(status.exitstatus).to eq(0)
21
+ end
22
+ after(:example) do
23
+ out, err, status = Open3.capture3(capcmd('murano', 'solution', 'delete', @project_name))
24
+ expect(out).to eq('')
25
+ expect(err).to eq('')
26
+ expect(status.exitstatus).to eq(0)
27
+
28
+ out, err, status = Open3.capture3(capcmd('murano', 'product', 'delete', @project_name))
29
+ expect(out).to eq('')
30
+ expect(err).to eq('')
31
+ expect(status.exitstatus).to eq(0)
32
+ end
33
+
34
+ context "without ProjectFile" do
35
+ before(:example) do
36
+ FileUtils.cp_r(File.join(@testdir, 'spec/fixtures/syncable_content/.'), '.')
37
+ FileUtils.move('assets','files')
38
+ FileUtils.mkpath('specs')
39
+ FileUtils.copy(File.join(@testdir, 'spec/fixtures/product_spec_files/lightbulb.yaml'), 'specs/resources.yaml')
40
+ end
41
+
42
+ it "status" do
43
+ out, err, status = Open3.capture3(capcmd('murano', 'status'))
44
+ expect(err).to eq('')
45
+ # Two problems with this output.
46
+ # 1: Order of files is not set
47
+ # 2: Path prefixes could be different.
48
+ olines = out.lines
49
+ expect(olines[0]).to eq("Adding:\n")
50
+ expect(olines[1..8]).to include(
51
+ a_string_matching(/ \+ A .*routes\/manyRoutes\.lua/),
52
+ a_string_matching(/ \+ A .*routes\/manyRoutes\.lua:4/),
53
+ a_string_matching(/ \+ A .*routes\/manyRoutes\.lua:7/),
54
+ a_string_matching(/ \+ A .*routes\/singleRoute\.lua/),
55
+ a_string_matching(/ \+ S .*files\/icon\.png/),
56
+ a_string_matching(/ \+ S .*files\/index\.html/),
57
+ a_string_matching(/ \+ S .*files\/js\/script\.js/),
58
+ a_string_matching(/ \+ M .*modules\/table_util\.lua/),
59
+ )
60
+ expect(olines[9]).to eq("Deleteing:\n")
61
+ expect(olines[10..11]).to include(
62
+ " - M my_library\n",
63
+ " - E user_account\n",
64
+ )
65
+ expect(olines[12]).to eq("Changing:\n")
66
+ expect(olines[13..14]).to include(
67
+ a_string_matching(/ M E .*services\/devdata\.lua/),
68
+ a_string_matching(/ M E .*services\/timers\.lua/),
69
+ )
70
+ expect(status.exitstatus).to eq(0)
71
+ end
72
+
73
+ it "matches file path" do
74
+ out, err, status = Open3.capture3(capcmd('murano', 'status', '**/icon.png'))
75
+ expect(err).to eq('')
76
+ olines = out.lines
77
+ expect(olines[0]).to eq("Adding:\n")
78
+ expect(olines[1]).to a_string_matching(/ \+ S .*files\/icon\.png/)
79
+ expect(olines[2]).to eq("Deleteing:\n")
80
+ expect(olines[3]).to eq("Changing:\n")
81
+ expect(status.exitstatus).to eq(0)
82
+ end
83
+
84
+ it "matches route" do
85
+ out, err, status = Open3.capture3(capcmd('murano', 'status', '#put#'))
86
+ expect(err).to eq('')
87
+ olines = out.lines
88
+ expect(olines[0]).to eq("Adding:\n")
89
+ expect(olines[1]).to a_string_matching(/ \+ A .*routes\/manyRoutes\.lua:4/)
90
+ expect(olines[2]).to eq("Deleteing:\n")
91
+ expect(olines[3]).to eq("Changing:\n")
92
+ expect(status.exitstatus).to eq(0)
93
+ end
94
+ end
95
+
96
+ context "with ProjectFile" do
97
+ before(:example) do
98
+ FileUtils.cp_r(File.join(@testdir, 'spec/fixtures/syncable_content/.'), '.')
99
+ FileUtils.move('assets','files')
100
+ FileUtils.mkpath('specs')
101
+ FileUtils.copy(File.join(@testdir, 'spec/fixtures/product_spec_files/lightbulb.yaml'), 'specs/resources.yaml')
102
+ FileUtils.copy(File.join(@testdir, 'spec/fixtures/ProjectFiles/only_meta.yaml'), 'test.murano')
103
+ end
104
+
105
+ it "status" do
106
+ out, err, status = Open3.capture3(capcmd('murano', 'status'))
107
+ expect(err).to eq('')
108
+ olines = out.lines
109
+ expect(olines[0]).to eq("Adding:\n")
110
+ expect(olines[1..8]).to include(
111
+ a_string_matching(/ \+ A .*routes\/manyRoutes\.lua/),
112
+ a_string_matching(/ \+ A .*routes\/manyRoutes\.lua:4/),
113
+ a_string_matching(/ \+ A .*routes\/manyRoutes\.lua:7/),
114
+ a_string_matching(/ \+ A .*routes\/singleRoute\.lua/),
115
+ a_string_matching(/ \+ S .*files\/icon\.png/),
116
+ a_string_matching(/ \+ S .*files\/index\.html/),
117
+ a_string_matching(/ \+ S .*files\/js\/script\.js/),
118
+ a_string_matching(/ \+ M .*modules\/table_util\.lua/),
119
+ )
120
+ expect(olines[9]).to eq("Deleteing:\n")
121
+ expect(olines[10..11]).to include(
122
+ " - M my_library\n",
123
+ " - E user_account\n",
124
+ )
125
+ expect(olines[12]).to eq("Changing:\n")
126
+ expect(olines[13..14]).to include(
127
+ a_string_matching(/ M E .*services\/devdata\.lua/),
128
+ a_string_matching(/ M E .*services\/timers\.lua/),
129
+ )
130
+ expect(status.exitstatus).to eq(0)
131
+ end
132
+ end
133
+
134
+ context "with Solutionfile 0.2.0" do
135
+ before(:example) do
136
+ FileUtils.cp_r(File.join(@testdir, 'spec/fixtures/syncable_content/.'), '.')
137
+ FileUtils.move('assets','files')
138
+ FileUtils.mkpath('specs')
139
+ FileUtils.copy(File.join(@testdir, 'spec/fixtures/product_spec_files/lightbulb.yaml'), 'specs/resources.yaml')
140
+ File.open('Solutionfile.json', 'wb') do |io|
141
+ io << {
142
+ :default_page => 'index.html',
143
+ :file_dir => 'files',
144
+ :custom_api => 'routes/manyRoutes.lua',
145
+ :modules => {
146
+ :table_util => 'modules/table_util.lua'
147
+ },
148
+ :event_handler => {
149
+ :device => {
150
+ :datapoint => 'services/devdata.lua'
151
+ }
152
+ }
153
+ }.to_json
154
+ end
155
+ end
156
+
157
+ it "status" do
158
+ out, err, status = Open3.capture3(capcmd('murano', 'status'))
159
+ expect(err).to eq('')
160
+ olines = out.lines
161
+ expect(olines[0]).to eq("Adding:\n")
162
+ expect(olines[1..7]).to include(
163
+ a_string_matching(/ \+ A .*routes\/manyRoutes\.lua/),
164
+ a_string_matching(/ \+ A .*routes\/manyRoutes\.lua:4/),
165
+ a_string_matching(/ \+ A .*routes\/manyRoutes\.lua:7/),
166
+ a_string_matching(/ \+ S .*files\/icon\.png/),
167
+ a_string_matching(/ \+ S .*files\/index\.html/),
168
+ a_string_matching(/ \+ S .*files\/js\/script\.js/),
169
+ a_string_matching(/ \+ M .*modules\/table_util\.lua/),
170
+ )
171
+ expect(olines[8]).to eq("Deleteing:\n")
172
+ expect(olines[9..11]).to include(
173
+ " - M my_library\n",
174
+ " - E user_account\n",
175
+ " - E timer_timer\n",
176
+ )
177
+ expect(olines[12]).to eq("Changing:\n")
178
+ expect(olines[13..14]).to include(
179
+ a_string_matching(/ M E .*services\/devdata\.lua/),
180
+ )
181
+ expect(status.exitstatus).to eq(0)
182
+ end
183
+ end
184
+
185
+ context "with Solutionfile 0.3.0" do
186
+ before(:example) do
187
+ FileUtils.cp_r(File.join(@testdir, 'spec/fixtures/syncable_content/.'), '.')
188
+ FileUtils.move('assets','files')
189
+ FileUtils.mkpath('specs')
190
+ FileUtils.copy(File.join(@testdir, 'spec/fixtures/product_spec_files/lightbulb.yaml'), 'specs/resources.yaml')
191
+ File.open('Solutionfile.json', 'wb') do |io|
192
+ io << {
193
+ :default_page => 'index.html',
194
+ :assets => 'files',
195
+ :routes => 'routes/manyRoutes.lua',
196
+ :modules => {
197
+ :table_util => 'modules/table_util.lua'
198
+ },
199
+ :services => {
200
+ :device => {
201
+ :datapoint => 'services/devdata.lua'
202
+ }
203
+ },
204
+ :version => '0.3.0',
205
+ }.to_json
206
+ end
207
+ end
208
+
209
+ it "status" do
210
+ out, err, status = Open3.capture3(capcmd('murano', 'status'))
211
+ expect(err).to eq('')
212
+ olines = out.lines
213
+ expect(olines[0]).to eq("Adding:\n")
214
+ expect(olines[1..7]).to include(
215
+ a_string_matching(/ \+ A .*routes\/manyRoutes\.lua/),
216
+ a_string_matching(/ \+ A .*routes\/manyRoutes\.lua:4/),
217
+ a_string_matching(/ \+ A .*routes\/manyRoutes\.lua:7/),
218
+ a_string_matching(/ \+ S .*files\/icon\.png/),
219
+ a_string_matching(/ \+ S .*files\/index\.html/),
220
+ a_string_matching(/ \+ S .*files\/js\/script\.js/),
221
+ a_string_matching(/ \+ M .*modules\/table_util\.lua/),
222
+ )
223
+ expect(olines[8]).to eq("Deleteing:\n")
224
+ expect(olines[9..11]).to include(
225
+ " - M my_library\n",
226
+ " - E user_account\n",
227
+ " - E timer_timer\n",
228
+ )
229
+ expect(olines[12]).to eq("Changing:\n")
230
+ expect(olines[13..14]).to include(
231
+ a_string_matching(/ M E .*services\/devdata\.lua/),
232
+ )
233
+ expect(status.exitstatus).to eq(0)
234
+ end
235
+ end
236
+
237
+ end
238
+
239
+ # vim: set ai et sw=2 ts=2 :
@@ -0,0 +1,86 @@
1
+ require 'fileutils'
2
+ require 'open3'
3
+ require 'pathname'
4
+ require 'cmd_common'
5
+
6
+ RSpec.describe 'murano syncdown', :cmd, :needs_password do
7
+ include_context "CI_CMD"
8
+
9
+ before(:example) do
10
+ @project_name = rname('syncdownTest')
11
+ out, err, status = Open3.capture3(capcmd('murano', 'solution', 'create', @project_name, '--save'))
12
+ expect(err).to eq('')
13
+ expect(out.chomp).to match(/^[a-zA-Z0-9]+$/)
14
+ expect(status.exitstatus).to eq(0)
15
+
16
+ out, err, status = Open3.capture3(capcmd('murano', 'product', 'create', @project_name, '--save'))
17
+ expect(err).to eq('')
18
+ expect(out.chomp).to match(/^[a-zA-Z0-9]+$/)
19
+ expect(status.exitstatus).to eq(0)
20
+ end
21
+ after(:example) do
22
+ out, err, status = Open3.capture3(capcmd('murano', 'solution', 'delete', @project_name))
23
+ expect(out).to eq('')
24
+ expect(err).to eq('')
25
+ expect(status.exitstatus).to eq(0)
26
+
27
+ out, err, status = Open3.capture3(capcmd('murano', 'product', 'delete', @project_name))
28
+ expect(out).to eq('')
29
+ expect(err).to eq('')
30
+ expect(status.exitstatus).to eq(0)
31
+ end
32
+
33
+ context "without ProjectFile" do
34
+ before(:example) do
35
+ FileUtils.cp_r(File.join(@testdir, 'spec/fixtures/syncable_content/.'), '.')
36
+ FileUtils.move('assets','files')
37
+ #FileUtils.mkpath('specs')
38
+ #FileUtils.copy(File.join(@testdir, 'spec/fixtures/product_spec_files/lightbulb.yaml'), 'specs/resources.yaml')
39
+ end
40
+
41
+ it "syncdown" do
42
+ out, err, status = Open3.capture3(capcmd('murano', 'syncup'))
43
+ expect(out).to eq('')
44
+ expect(err).to eq('')
45
+ expect(status.exitstatus).to eq(0)
46
+
47
+ FileUtils.rm_r(['files', 'modules', 'routes', 'services'])
48
+ expect(Dir['**/*']).to eq([])
49
+
50
+ out, err, status = Open3.capture3(capcmd('murano', 'syncdown'))
51
+ expect(out).to eq('')
52
+ expect(err.lines).to include(
53
+ a_string_ending_with("routes\e[0m\n"),
54
+ a_string_ending_with("files\e[0m\n"),
55
+ a_string_ending_with("modules\e[0m\n"),
56
+ a_string_ending_with("services\e[0m\n"),
57
+ )
58
+ expect(status.exitstatus).to eq(0)
59
+
60
+ after = Dir['**/*'].sort
61
+ expect(after).to include("files",
62
+ "files/icon.png",
63
+ "files/index.html",
64
+ "files/js",
65
+ "files/js/script.js",
66
+ "modules",
67
+ "modules/table_util.lua",
68
+ "routes",
69
+ "routes/api-fire-{code}.delete.lua",
70
+ "routes/api-fire-{code}.put.lua",
71
+ "routes/api-fire.post.lua",
72
+ "routes/api-onfire.get.lua",
73
+ "services",
74
+ "services/device_datapoint.lua",
75
+ "services/timer_timer.lua")
76
+ end
77
+ end
78
+
79
+
80
+
81
+ # TODO: With ProjectFile
82
+ # TODO: With Solutionfile 0.2.0
83
+ # TODO: With Solutionfile 0.3.0
84
+ end
85
+
86
+ # vim: set ai et sw=2 ts=2 :
@@ -0,0 +1,62 @@
1
+ require 'fileutils'
2
+ require 'open3'
3
+ require 'pathname'
4
+ require 'cmd_common'
5
+
6
+ RSpec.describe 'murano syncup', :cmd, :needs_password do
7
+ include_context "CI_CMD"
8
+
9
+ before(:example) do
10
+ @project_name = rname('syncupTest')
11
+ out, err, status = Open3.capture3(capcmd('murano', 'solution', 'create', @project_name, '--save'))
12
+ expect(err).to eq('')
13
+ expect(out.chomp).to match(/^[a-zA-Z0-9]+$/)
14
+ expect(status.exitstatus).to eq(0)
15
+
16
+ out, err, status = Open3.capture3(capcmd('murano', 'product', 'create', @project_name, '--save'))
17
+ expect(err).to eq('')
18
+ expect(out.chomp).to match(/^[a-zA-Z0-9]+$/)
19
+ expect(status.exitstatus).to eq(0)
20
+ end
21
+ after(:example) do
22
+ out, err, status = Open3.capture3(capcmd('murano', 'solution', 'delete', @project_name))
23
+ expect(out).to eq('')
24
+ expect(err).to eq('')
25
+ expect(status.exitstatus).to eq(0)
26
+
27
+ out, err, status = Open3.capture3(capcmd('murano', 'product', 'delete', @project_name))
28
+ expect(out).to eq('')
29
+ expect(err).to eq('')
30
+ expect(status.exitstatus).to eq(0)
31
+ end
32
+
33
+ context "without ProjectFile" do
34
+ before(:example) do
35
+ FileUtils.cp_r(File.join(@testdir, 'spec/fixtures/syncable_content/.'), '.')
36
+ FileUtils.move('assets','files')
37
+ FileUtils.mkpath('specs')
38
+ FileUtils.copy(File.join(@testdir, 'spec/fixtures/product_spec_files/lightbulb.yaml'), 'specs/resources.yaml')
39
+ end
40
+
41
+ it "syncup" do
42
+ out, err, status = Open3.capture3(capcmd('murano', 'syncup'))
43
+ expect(out).to eq('')
44
+ expect(err).to eq('')
45
+ expect(status.exitstatus).to eq(0)
46
+
47
+ out, err, status = Open3.capture3(capcmd('murano', 'status'))
48
+ expect(out).to start_with(%{Adding:\nDeleteing:\nChanging:\n})
49
+ # Due to timestamp races, there might be modules or services in Changing.
50
+ expect(err).to eq('')
51
+ expect(status.exitstatus).to eq(0)
52
+ end
53
+ end
54
+
55
+
56
+
57
+ # TODO: With ProjectFile
58
+ # TODO: With Solutionfile 0.2.0
59
+ # TODO: With Solutionfile 0.3.0
60
+ end
61
+
62
+ # vim: set ai et sw=2 ts=2 :