tem_multi_updater 0.2 → 0.3
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG +2 -0
- data/Manifest +1 -0
- data/bin/tem_multi_reset_fw +22 -0
- data/lib/tem_multi_updater/updater.rb +5 -2
- data/tem_multi_updater.gemspec +4 -5
- data/test/updater_test.rb +7 -0
- metadata +4 -1
data/CHANGELOG
CHANGED
data/Manifest
CHANGED
@@ -0,0 +1,22 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
#
|
3
|
+
# Launcher for the multi-updater code with forced updating.
|
4
|
+
#
|
5
|
+
# Author:: Victor Costan
|
6
|
+
# Copyright:: Copyright (C) 2009 Massachusetts Institute of Technology
|
7
|
+
# License:: MIT
|
8
|
+
#
|
9
|
+
# Usage: tem_multi_reset_fw [host[:port]]
|
10
|
+
# The host:port should point to the RPC port of the tem_multi_proxy server.
|
11
|
+
# The default host is localhost, and the default port is 9000.
|
12
|
+
|
13
|
+
require 'logger'
|
14
|
+
require 'rubygems'
|
15
|
+
require 'tem_multi_proxy'
|
16
|
+
require 'tem_multi_updater'
|
17
|
+
|
18
|
+
server_addr = ARGV[0] || 'localhost'
|
19
|
+
logger = Logger.new STDERR
|
20
|
+
logger.level = Logger::INFO
|
21
|
+
updater = Tem::MultiUpdater::Updater.new logger, server_addr, :force => true
|
22
|
+
updater.run
|
@@ -18,9 +18,10 @@ class Updater
|
|
18
18
|
# logger:: receives update progress notifications
|
19
19
|
# multiproxy_server_addr:: the address (host or host:port) of the
|
20
20
|
# tem_multi_proxy RPC port
|
21
|
-
def initialize(logger, multiproxy_server_addr)
|
21
|
+
def initialize(logger, multiproxy_server_addr, options = {})
|
22
22
|
@logger = logger
|
23
23
|
@server_addr = multiproxy_server_addr
|
24
|
+
@options = options
|
24
25
|
@pending = nil
|
25
26
|
@pending_mx, @pending_cv = Mutex.new, ConditionVariable.new
|
26
27
|
end
|
@@ -124,7 +125,9 @@ class Updater
|
|
124
125
|
#
|
125
126
|
# Args:
|
126
127
|
# transport_config:: smart-card transport connecting to the TEM card
|
127
|
-
def needs_update?(transport)
|
128
|
+
def needs_update?(transport)
|
129
|
+
return true if @options[:force]
|
130
|
+
|
128
131
|
begin
|
129
132
|
tem = Tem::Session.new transport
|
130
133
|
tem_version = tem.fw_version
|
data/tem_multi_updater.gemspec
CHANGED
@@ -2,17 +2,16 @@
|
|
2
2
|
|
3
3
|
Gem::Specification.new do |s|
|
4
4
|
s.name = %q{tem_multi_updater}
|
5
|
-
s.version = "0.
|
5
|
+
s.version = "0.3"
|
6
6
|
|
7
7
|
s.required_rubygems_version = Gem::Requirement.new(">= 1.2") if s.respond_to? :required_rubygems_version=
|
8
8
|
s.authors = ["Victor Costan"]
|
9
9
|
s.date = %q{2009-11-10}
|
10
|
-
s.default_executable = %q{tem_multi_update_fw}
|
11
10
|
s.description = %q{Updates the firmware on all TEMs connected to a tem_multi_proxy.}
|
12
11
|
s.email = %q{victor@costan.us}
|
13
|
-
s.executables = ["tem_multi_update_fw"]
|
14
|
-
s.extra_rdoc_files = ["CHANGELOG", "LICENSE", "README", "bin/tem_multi_update_fw", "lib/tem_multi_updater.rb", "lib/tem_multi_updater/updater.rb"]
|
15
|
-
s.files = ["CHANGELOG", "LICENSE", "Manifest", "README", "Rakefile", "bin/tem_multi_update_fw", "lib/tem_multi_updater.rb", "lib/tem_multi_updater/updater.rb", "test/integration_test.rb", "test/updater_test.rb", "tem_multi_updater.gemspec"]
|
12
|
+
s.executables = ["tem_multi_reset_fw", "tem_multi_update_fw"]
|
13
|
+
s.extra_rdoc_files = ["CHANGELOG", "LICENSE", "README", "bin/tem_multi_reset_fw", "bin/tem_multi_update_fw", "lib/tem_multi_updater.rb", "lib/tem_multi_updater/updater.rb"]
|
14
|
+
s.files = ["CHANGELOG", "LICENSE", "Manifest", "README", "Rakefile", "bin/tem_multi_reset_fw", "bin/tem_multi_update_fw", "lib/tem_multi_updater.rb", "lib/tem_multi_updater/updater.rb", "test/integration_test.rb", "test/updater_test.rb", "tem_multi_updater.gemspec"]
|
16
15
|
s.homepage = %q{http://tem.rubyforge.org}
|
17
16
|
s.rdoc_options = ["--line-numbers", "--inline-source", "--title", "Tem_multi_updater", "--main", "README"]
|
18
17
|
s.require_paths = ["lib"]
|
data/test/updater_test.rb
CHANGED
@@ -26,6 +26,13 @@ class UpdaterTest < Test::Unit::TestCase
|
|
26
26
|
super
|
27
27
|
end
|
28
28
|
|
29
|
+
def test_reset_switch
|
30
|
+
updater = Tem::MultiUpdater::Updater.new Logger.new(StringIO.new),
|
31
|
+
@server_addr, :force => true
|
32
|
+
flexmock(Tem::Session).should_receive(:new).never
|
33
|
+
assert_equal true, updater.needs_update?(:bogus_transport)
|
34
|
+
end
|
35
|
+
|
29
36
|
def test_dead_proxy
|
30
37
|
flexmock(Tem::MultiProxy::Client).should_receive(:query_tems).
|
31
38
|
with(@server_addr).and_return(nil)
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: tem_multi_updater
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: "0.
|
4
|
+
version: "0.3"
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Victor Costan
|
@@ -65,6 +65,7 @@ dependencies:
|
|
65
65
|
description: Updates the firmware on all TEMs connected to a tem_multi_proxy.
|
66
66
|
email: victor@costan.us
|
67
67
|
executables:
|
68
|
+
- tem_multi_reset_fw
|
68
69
|
- tem_multi_update_fw
|
69
70
|
extensions: []
|
70
71
|
|
@@ -72,6 +73,7 @@ extra_rdoc_files:
|
|
72
73
|
- CHANGELOG
|
73
74
|
- LICENSE
|
74
75
|
- README
|
76
|
+
- bin/tem_multi_reset_fw
|
75
77
|
- bin/tem_multi_update_fw
|
76
78
|
- lib/tem_multi_updater.rb
|
77
79
|
- lib/tem_multi_updater/updater.rb
|
@@ -81,6 +83,7 @@ files:
|
|
81
83
|
- Manifest
|
82
84
|
- README
|
83
85
|
- Rakefile
|
86
|
+
- bin/tem_multi_reset_fw
|
84
87
|
- bin/tem_multi_update_fw
|
85
88
|
- lib/tem_multi_updater.rb
|
86
89
|
- lib/tem_multi_updater/updater.rb
|