smart_proxy_remote_execution_ssh 0.0.12 → 0.0.13

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 0bf9a9cd391f128780ac403359755a08e43b86e8
4
- data.tar.gz: be0a53b4f7b689bda67cdb2b28fa89c22e3a2878
3
+ metadata.gz: 91afb2738282d322802d7b56291b5240cb62b478
4
+ data.tar.gz: b42e795f671e0165e60fe821ca12de4c70884fd1
5
5
  SHA512:
6
- metadata.gz: 8c1b58e4274b142141079415c701b502bcb68445c9d0bbe8339a69500e3e6ad517bbb11646357f1bfa04b8784a557d75cf93f162a6edb480bd47dcb3729dd0ae
7
- data.tar.gz: 7be875190530ba3009b69a7a2e91caa999e4f9c14f43fa58b90423da2e59a50d8ec10d5d332f1a7795bb1561becd2331d74052f0fc88375bdc57138a298d0ed0
6
+ metadata.gz: 17ce48cae4e47ebb886157156f0d5e35271b184f84e07762dff735bbe32ae458a907a6956a20d1f18c686dc24802f48018eff8ec8a341071f1c65a5a6bd7f4ca
7
+ data.tar.gz: bb75cd72b3fbb5a28c63c7b28a6067ac02d6f568ed40bd759dcdd3102b4b4cae5af24e4631276a2220dd8b094553fc0c83697bccc6ba597114b8a351ff520e25
@@ -85,6 +85,9 @@ module Proxy::RemoteExecution::Ssh
85
85
  tries = 0
86
86
  begin
87
87
  session.process(0)
88
+ rescue Net::SSH::Disconnect => e
89
+ session.shutdown!
90
+ raise e
88
91
  rescue => e
89
92
  @logger.error("Error while processing ssh channel: #{e.class} #{e.message}\n #{e.backtrace.join("\n")}")
90
93
  tries += 1
@@ -5,6 +5,8 @@ module Proxy::RemoteExecution::Ssh
5
5
  # Dynflow action. It runs just one (actor) thread for all the commands
6
6
  # running in the system and updates the Dynflow actions periodically.
7
7
  class Session < ::Dynflow::Actor
8
+ EXPECTED_POWER_ACTION_MESSAGES = ["restart host", "shutdown host"]
9
+
8
10
  def initialize(options = {})
9
11
  @clock = options[:clock] || Dynflow::Clock.spawn('proxy-dispatcher-clock')
10
12
  @logger = options[:logger] || Logger.new($stderr)
@@ -55,6 +57,15 @@ module Proxy::RemoteExecution::Ssh
55
57
  finish_command
56
58
  end
57
59
  end
60
+ rescue Net::SSH::Disconnect => e
61
+ check_expecting_disconnect
62
+ if @expecting_disconnect
63
+ @command_buffer << CommandUpdate::StatusData.new(0)
64
+ else
65
+ @command_buffer.concat(CommandUpdate.encode_exception("Failed to refresh the connector", e, true))
66
+ end
67
+ refresh_command_buffer
68
+ finish_command
58
69
  rescue => e
59
70
  @command_buffer.concat(CommandUpdate.encode_exception("Failed to refresh the connector", e, false))
60
71
  ensure
@@ -65,6 +76,7 @@ module Proxy::RemoteExecution::Ssh
65
76
  def refresh_command_buffer
66
77
  @logger.debug("command #{@command} got new output: #{@command_buffer.inspect}")
67
78
  command_update = CommandUpdate.new(@command_buffer)
79
+ check_expecting_disconnect
68
80
  @command.suspended_action << command_update
69
81
  @command_buffer = []
70
82
  if command_update.exit_status
@@ -186,5 +198,16 @@ module Proxy::RemoteExecution::Ssh
186
198
  @refresh_planned = true
187
199
  end
188
200
  end
201
+
202
+ # when a remote server disconnects, it's hard to tell if it was on purpose (when calling reboot)
203
+ # or it's an error. When it's expected, we expect the script to produce 'restart host' as
204
+ # its last command output
205
+ def check_expecting_disconnect
206
+ last_output = @command_buffer.reverse.find { |d| d.is_a? CommandUpdate::StdoutData }
207
+ return unless last_output
208
+ if EXPECTED_POWER_ACTION_MESSAGES.any? { |message| last_output.data =~ /^#{message}/ }
209
+ @expecting_disconnect = true
210
+ end
211
+ end
189
212
  end
190
213
  end
@@ -1,7 +1,7 @@
1
1
  module Proxy
2
2
  module RemoteExecution
3
3
  module Ssh
4
- VERSION = '0.0.12'
4
+ VERSION = '0.0.13'
5
5
  end
6
6
  end
7
7
  end
metadata CHANGED
@@ -1,97 +1,97 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: smart_proxy_remote_execution_ssh
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.12
4
+ version: 0.0.13
5
5
  platform: ruby
6
6
  authors:
7
7
  - Ivan Nečas
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2016-01-21 00:00:00.000000000 Z
11
+ date: 2016-02-16 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bundler
15
15
  requirement: !ruby/object:Gem::Requirement
16
16
  requirements:
17
- - - "~>"
17
+ - - ~>
18
18
  - !ruby/object:Gem::Version
19
19
  version: '1.7'
20
20
  type: :development
21
21
  prerelease: false
22
22
  version_requirements: !ruby/object:Gem::Requirement
23
23
  requirements:
24
- - - "~>"
24
+ - - ~>
25
25
  - !ruby/object:Gem::Version
26
26
  version: '1.7'
27
27
  - !ruby/object:Gem::Dependency
28
28
  name: rake
29
29
  requirement: !ruby/object:Gem::Requirement
30
30
  requirements:
31
- - - "~>"
31
+ - - ~>
32
32
  - !ruby/object:Gem::Version
33
33
  version: '10.0'
34
34
  type: :development
35
35
  prerelease: false
36
36
  version_requirements: !ruby/object:Gem::Requirement
37
37
  requirements:
38
- - - "~>"
38
+ - - ~>
39
39
  - !ruby/object:Gem::Version
40
40
  version: '10.0'
41
41
  - !ruby/object:Gem::Dependency
42
42
  name: minitest
43
43
  requirement: !ruby/object:Gem::Requirement
44
44
  requirements:
45
- - - ">="
45
+ - - '>='
46
46
  - !ruby/object:Gem::Version
47
47
  version: '0'
48
48
  type: :development
49
49
  prerelease: false
50
50
  version_requirements: !ruby/object:Gem::Requirement
51
51
  requirements:
52
- - - ">="
52
+ - - '>='
53
53
  - !ruby/object:Gem::Version
54
54
  version: '0'
55
55
  - !ruby/object:Gem::Dependency
56
56
  name: mocha
57
57
  requirement: !ruby/object:Gem::Requirement
58
58
  requirements:
59
- - - "~>"
59
+ - - ~>
60
60
  - !ruby/object:Gem::Version
61
61
  version: '1'
62
62
  type: :development
63
63
  prerelease: false
64
64
  version_requirements: !ruby/object:Gem::Requirement
65
65
  requirements:
66
- - - "~>"
66
+ - - ~>
67
67
  - !ruby/object:Gem::Version
68
68
  version: '1'
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: webmock
71
71
  requirement: !ruby/object:Gem::Requirement
72
72
  requirements:
73
- - - "~>"
73
+ - - ~>
74
74
  - !ruby/object:Gem::Version
75
75
  version: '1'
76
76
  type: :development
77
77
  prerelease: false
78
78
  version_requirements: !ruby/object:Gem::Requirement
79
79
  requirements:
80
- - - "~>"
80
+ - - ~>
81
81
  - !ruby/object:Gem::Version
82
82
  version: '1'
83
83
  - !ruby/object:Gem::Dependency
84
84
  name: rack-test
85
85
  requirement: !ruby/object:Gem::Requirement
86
86
  requirements:
87
- - - "~>"
87
+ - - ~>
88
88
  - !ruby/object:Gem::Version
89
89
  version: '0'
90
90
  type: :development
91
91
  prerelease: false
92
92
  version_requirements: !ruby/object:Gem::Requirement
93
93
  requirements:
94
- - - "~>"
94
+ - - ~>
95
95
  - !ruby/object:Gem::Version
96
96
  version: '0'
97
97
  - !ruby/object:Gem::Dependency
@@ -112,42 +112,42 @@ dependencies:
112
112
  name: smart_proxy_dynflow
113
113
  requirement: !ruby/object:Gem::Requirement
114
114
  requirements:
115
- - - "~>"
115
+ - - ~>
116
116
  - !ruby/object:Gem::Version
117
117
  version: 0.0.3
118
118
  type: :runtime
119
119
  prerelease: false
120
120
  version_requirements: !ruby/object:Gem::Requirement
121
121
  requirements:
122
- - - "~>"
122
+ - - ~>
123
123
  - !ruby/object:Gem::Version
124
124
  version: 0.0.3
125
125
  - !ruby/object:Gem::Dependency
126
126
  name: net-ssh
127
127
  requirement: !ruby/object:Gem::Requirement
128
128
  requirements:
129
- - - ">="
129
+ - - '>='
130
130
  - !ruby/object:Gem::Version
131
131
  version: '0'
132
132
  type: :runtime
133
133
  prerelease: false
134
134
  version_requirements: !ruby/object:Gem::Requirement
135
135
  requirements:
136
- - - ">="
136
+ - - '>='
137
137
  - !ruby/object:Gem::Version
138
138
  version: '0'
139
139
  - !ruby/object:Gem::Dependency
140
140
  name: net-scp
141
141
  requirement: !ruby/object:Gem::Requirement
142
142
  requirements:
143
- - - ">="
143
+ - - '>='
144
144
  - !ruby/object:Gem::Version
145
145
  version: '0'
146
146
  type: :runtime
147
147
  prerelease: false
148
148
  version_requirements: !ruby/object:Gem::Requirement
149
149
  requirements:
150
- - - ">="
150
+ - - '>='
151
151
  - !ruby/object:Gem::Version
152
152
  version: '0'
153
153
  description: |2
@@ -184,12 +184,12 @@ require_paths:
184
184
  - lib
185
185
  required_ruby_version: !ruby/object:Gem::Requirement
186
186
  requirements:
187
- - - ">="
187
+ - - '>='
188
188
  - !ruby/object:Gem::Version
189
189
  version: '0'
190
190
  required_rubygems_version: !ruby/object:Gem::Requirement
191
191
  requirements:
192
- - - ">="
192
+ - - '>='
193
193
  - !ruby/object:Gem::Version
194
194
  version: '0'
195
195
  requirements: []