zold 0.10.10 → 0.10.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
 - data/lib/zold/commands/node.rb +22 -19
 - data/lib/zold/node/farm.rb +20 -17
 - data/lib/zold/verbose_thread.rb +41 -0
 - data/lib/zold/version.rb +1 -1
 - data/test/node/fake_node.rb +2 -3
 - data/test/node/test_farm.rb +1 -1
 - data/test/test_tax.rb +1 -1
 - metadata +2 -1
 
    
        checksums.yaml
    CHANGED
    
    | 
         @@ -1,7 +1,7 @@ 
     | 
|
| 
       1 
1 
     | 
    
         
             
            ---
         
     | 
| 
       2 
2 
     | 
    
         
             
            SHA1:
         
     | 
| 
       3 
     | 
    
         
            -
              metadata.gz:  
     | 
| 
       4 
     | 
    
         
            -
              data.tar.gz:  
     | 
| 
      
 3 
     | 
    
         
            +
              metadata.gz: 1e2236b7567d7ba2d5c403278d42ec9e9385ab36
         
     | 
| 
      
 4 
     | 
    
         
            +
              data.tar.gz: a379df9335dcd1d79266e1393f2a38f8c4e93f95
         
     | 
| 
       5 
5 
     | 
    
         
             
            SHA512:
         
     | 
| 
       6 
     | 
    
         
            -
              metadata.gz:  
     | 
| 
       7 
     | 
    
         
            -
              data.tar.gz:  
     | 
| 
      
 6 
     | 
    
         
            +
              metadata.gz: 94ed101de88e700fcfd8bd785d73b8c999dacc4e0d802ead0309e318f59f315754245b5ef23779e8ccb6f46bc660ef52e014f4365062310f544310713aaf6e1a
         
     | 
| 
      
 7 
     | 
    
         
            +
              data.tar.gz: edf18e39339f221a86d7d7a368ba45190fa8dab3dda99be33e2bd36e340a149466531f3387ded9b09f04d02e43ee0095e31afa8d9348b9d37707a6478fc3d84e
         
     | 
    
        data/lib/zold/commands/node.rb
    CHANGED
    
    | 
         @@ -22,6 +22,7 @@ require 'slop' 
     | 
|
| 
       22 
22 
     | 
    
         
             
            require_relative '../score'
         
     | 
| 
       23 
23 
     | 
    
         
             
            require_relative '../wallets'
         
     | 
| 
       24 
24 
     | 
    
         
             
            require_relative '../remotes'
         
     | 
| 
      
 25 
     | 
    
         
            +
            require_relative '../verbose_thread'
         
     | 
| 
       25 
26 
     | 
    
         
             
            require_relative '../node/entrance'
         
     | 
| 
       26 
27 
     | 
    
         
             
            require_relative '../node/front'
         
     | 
| 
       27 
28 
     | 
    
         
             
            require_relative '../node/farm'
         
     | 
| 
         @@ -71,34 +72,34 @@ module Zold 
     | 
|
| 
       71 
72 
     | 
    
         
             
                    return
         
     | 
| 
       72 
73 
     | 
    
         
             
                  end
         
     | 
| 
       73 
74 
     | 
    
         
             
                  raise '--invoice is mandatory' unless opts[:invoice]
         
     | 
| 
       74 
     | 
    
         
            -
                   
     | 
| 
       75 
     | 
    
         
            -
                   
     | 
| 
      
 75 
     | 
    
         
            +
                  Front.set(:log, @log)
         
     | 
| 
      
 76 
     | 
    
         
            +
                  Front.set(:logging, @log.debug?)
         
     | 
| 
       76 
77 
     | 
    
         
             
                  FileUtils.mkdir_p(opts[:home])
         
     | 
| 
       77 
     | 
    
         
            -
                   
     | 
| 
       78 
     | 
    
         
            -
                   
     | 
| 
      
 78 
     | 
    
         
            +
                  Front.set(:home, opts[:home])
         
     | 
| 
      
 79 
     | 
    
         
            +
                  Front.set(
         
     | 
| 
       79 
80 
     | 
    
         
             
                    :server_settings,
         
     | 
| 
       80 
81 
     | 
    
         
             
                    Logger: WebrickLog.new(@log),
         
     | 
| 
       81 
82 
     | 
    
         
             
                    AccessLog: []
         
     | 
| 
       82 
83 
     | 
    
         
             
                  )
         
     | 
| 
       83 
84 
     | 
    
         
             
                  if opts['standalone']
         
     | 
| 
       84 
85 
     | 
    
         
             
                    remotes = Remotes::Empty.new
         
     | 
| 
       85 
     | 
    
         
            -
                    @log.debug('Running in standalone mode!')
         
     | 
| 
      
 86 
     | 
    
         
            +
                    @log.debug('Running in standalone mode! (will never talk to other remotes)')
         
     | 
| 
       86 
87 
     | 
    
         
             
                  else
         
     | 
| 
       87 
88 
     | 
    
         
             
                    remotes = Remotes.new(File.join(opts[:home], 'zold-remotes'))
         
     | 
| 
       88 
89 
     | 
    
         
             
                  end
         
     | 
| 
       89 
90 
     | 
    
         
             
                  wallets = Wallets.new(File.join(opts[:home], 'zold-wallets'))
         
     | 
| 
       90 
     | 
    
         
            -
                   
     | 
| 
       91 
     | 
    
         
            -
                   
     | 
| 
      
 91 
     | 
    
         
            +
                  Front.set(:wallets, wallets)
         
     | 
| 
      
 92 
     | 
    
         
            +
                  Front.set(:remotes, remotes)
         
     | 
| 
       92 
93 
     | 
    
         
             
                  copies = File.join(opts[:home], 'zold-copies')
         
     | 
| 
       93 
     | 
    
         
            -
                   
     | 
| 
      
 94 
     | 
    
         
            +
                  Front.set(:copies, copies)
         
     | 
| 
       94 
95 
     | 
    
         
             
                  address = "#{opts[:host]}:#{opts[:port]}".downcase
         
     | 
| 
       95 
     | 
    
         
            -
                   
     | 
| 
       96 
     | 
    
         
            -
                   
     | 
| 
      
 96 
     | 
    
         
            +
                  Front.set(:address, address)
         
     | 
| 
      
 97 
     | 
    
         
            +
                  Front.set(
         
     | 
| 
       97 
98 
     | 
    
         
             
                    :entrance, Entrance.new(wallets, remotes, copies, address, log: @log)
         
     | 
| 
       98 
99 
     | 
    
         
             
                  )
         
     | 
| 
       99 
     | 
    
         
            -
                   
     | 
| 
       100 
     | 
    
         
            -
                   
     | 
| 
       101 
     | 
    
         
            -
                   
     | 
| 
      
 100 
     | 
    
         
            +
                  Front.set(:root, Dir.pwd)
         
     | 
| 
      
 101 
     | 
    
         
            +
                  Front.set(:port, opts['bind-port'])
         
     | 
| 
      
 102 
     | 
    
         
            +
                  Front.set(:reboot, !opts['never-reboot'])
         
     | 
| 
       102 
103 
     | 
    
         
             
                  invoice = opts[:invoice]
         
     | 
| 
       103 
104 
     | 
    
         
             
                  unless invoice.include?('@')
         
     | 
| 
       104 
105 
     | 
    
         
             
                    require_relative 'pull'
         
     | 
| 
         @@ -112,17 +113,19 @@ module Zold 
     | 
|
| 
       112 
113 
     | 
    
         
             
                    opts[:port],
         
     | 
| 
       113 
114 
     | 
    
         
             
                    threads: opts[:threads], strength: opts[:strength]
         
     | 
| 
       114 
115 
     | 
    
         
             
                  )
         
     | 
| 
       115 
     | 
    
         
            -
                   
     | 
| 
      
 116 
     | 
    
         
            +
                  Front.set(:farm, farm)
         
     | 
| 
       116 
117 
     | 
    
         
             
                  update = Thread.start do
         
     | 
| 
       117 
     | 
    
         
            -
                     
     | 
| 
       118 
     | 
    
         
            -
                       
     | 
| 
       119 
     | 
    
         
            -
             
     | 
| 
       120 
     | 
    
         
            -
             
     | 
| 
      
 118 
     | 
    
         
            +
                    VerboseThread.new(@log).run do
         
     | 
| 
      
 119 
     | 
    
         
            +
                      loop do
         
     | 
| 
      
 120 
     | 
    
         
            +
                        sleep(60)
         
     | 
| 
      
 121 
     | 
    
         
            +
                        Remote.new(remotes: remotes, log: @log).run(%w[remote update --reboot])
         
     | 
| 
      
 122 
     | 
    
         
            +
                        @log.debug('Regular update of remote nodes succeeded')
         
     | 
| 
      
 123 
     | 
    
         
            +
                      end
         
     | 
| 
       121 
124 
     | 
    
         
             
                    end
         
     | 
| 
       122 
125 
     | 
    
         
             
                  end
         
     | 
| 
       123 
126 
     | 
    
         
             
                  @log.debug('Starting up the web front...')
         
     | 
| 
       124 
127 
     | 
    
         
             
                  begin
         
     | 
| 
       125 
     | 
    
         
            -
                     
     | 
| 
      
 128 
     | 
    
         
            +
                    Front.run!
         
     | 
| 
       126 
129 
     | 
    
         
             
                  ensure
         
     | 
| 
       127 
130 
     | 
    
         
             
                    farm.stop
         
     | 
| 
       128 
131 
     | 
    
         
             
                    update.exit
         
     | 
    
        data/lib/zold/node/farm.rb
    CHANGED
    
    | 
         @@ -21,6 +21,7 @@ 
     | 
|
| 
       21 
21 
     | 
    
         
             
            require 'time'
         
     | 
| 
       22 
22 
     | 
    
         
             
            require_relative '../log'
         
     | 
| 
       23 
23 
     | 
    
         
             
            require_relative '../score'
         
     | 
| 
      
 24 
     | 
    
         
            +
            require_relative '../verbose_thread'
         
     | 
| 
       24 
25 
     | 
    
         | 
| 
       25 
26 
     | 
    
         
             
            # The farm of scores.
         
     | 
| 
       26 
27 
     | 
    
         
             
            # Author:: Yegor Bugayenko (yegor256@gmail.com)
         
     | 
| 
         @@ -63,24 +64,26 @@ module Zold 
     | 
|
| 
       63 
64 
     | 
    
         
             
                  @scores << first
         
     | 
| 
       64 
65 
     | 
    
         
             
                  @threads = (1..threads).map do |t|
         
     | 
| 
       65 
66 
     | 
    
         
             
                    Thread.new do
         
     | 
| 
       66 
     | 
    
         
            -
                       
     | 
| 
       67 
     | 
    
         
            -
             
     | 
| 
       68 
     | 
    
         
            -
                         
     | 
| 
       69 
     | 
    
         
            -
             
     | 
| 
       70 
     | 
    
         
            -
             
     | 
| 
       71 
     | 
    
         
            -
                           
     | 
| 
       72 
     | 
    
         
            -
             
     | 
| 
       73 
     | 
    
         
            -
             
     | 
| 
       74 
     | 
    
         
            -
             
     | 
| 
       75 
     | 
    
         
            -
             
     | 
| 
      
 67 
     | 
    
         
            +
                      VerboseThread.new(@log).run do
         
     | 
| 
      
 68 
     | 
    
         
            +
                        Thread.current.name = "farm-#{t}"
         
     | 
| 
      
 69 
     | 
    
         
            +
                        loop do
         
     | 
| 
      
 70 
     | 
    
         
            +
                          s = @scores.pop
         
     | 
| 
      
 71 
     | 
    
         
            +
                          next unless s.valid?
         
     | 
| 
      
 72 
     | 
    
         
            +
                          @semaphore.synchronize do
         
     | 
| 
      
 73 
     | 
    
         
            +
                            before = @best.map(&:value).max
         
     | 
| 
      
 74 
     | 
    
         
            +
                            @best << s
         
     | 
| 
      
 75 
     | 
    
         
            +
                            after = @best.map(&:value).max
         
     | 
| 
      
 76 
     | 
    
         
            +
                            @best.reject! { |b| b.value < after }
         
     | 
| 
      
 77 
     | 
    
         
            +
                            @log.debug("#{Thread.current.name}: best is #{@best[0]}") if before != after
         
     | 
| 
      
 78 
     | 
    
         
            +
                          end
         
     | 
| 
      
 79 
     | 
    
         
            +
                          if @scores.length < 4
         
     | 
| 
      
 80 
     | 
    
         
            +
                            @scores << Score.new(
         
     | 
| 
      
 81 
     | 
    
         
            +
                              Time.now, host, port, @invoice,
         
     | 
| 
      
 82 
     | 
    
         
            +
                              strength: strength
         
     | 
| 
      
 83 
     | 
    
         
            +
                            )
         
     | 
| 
      
 84 
     | 
    
         
            +
                          end
         
     | 
| 
      
 85 
     | 
    
         
            +
                          @scores << s.next
         
     | 
| 
       76 
86 
     | 
    
         
             
                        end
         
     | 
| 
       77 
     | 
    
         
            -
                        if @scores.length < 4
         
     | 
| 
       78 
     | 
    
         
            -
                          @scores << Score.new(
         
     | 
| 
       79 
     | 
    
         
            -
                            Time.now, host, port, @invoice,
         
     | 
| 
       80 
     | 
    
         
            -
                            strength: strength
         
     | 
| 
       81 
     | 
    
         
            -
                          )
         
     | 
| 
       82 
     | 
    
         
            -
                        end
         
     | 
| 
       83 
     | 
    
         
            -
                        @scores << s.next
         
     | 
| 
       84 
87 
     | 
    
         
             
                      end
         
     | 
| 
       85 
88 
     | 
    
         
             
                    end
         
     | 
| 
       86 
89 
     | 
    
         
             
                  end
         
     | 
| 
         @@ -0,0 +1,41 @@ 
     | 
|
| 
      
 1 
     | 
    
         
            +
            # Copyright (c) 2018 Yegor Bugayenko
         
     | 
| 
      
 2 
     | 
    
         
            +
            #
         
     | 
| 
      
 3 
     | 
    
         
            +
            # Permission is hereby granted, free of charge, to any person obtaining a copy
         
     | 
| 
      
 4 
     | 
    
         
            +
            # of this software and associated documentation files (the 'Software'), to deal
         
     | 
| 
      
 5 
     | 
    
         
            +
            # in the Software without restriction, including without limitation the rights
         
     | 
| 
      
 6 
     | 
    
         
            +
            # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
         
     | 
| 
      
 7 
     | 
    
         
            +
            # copies of the Software, and to permit persons to whom the Software is
         
     | 
| 
      
 8 
     | 
    
         
            +
            # furnished to do so, subject to the following conditions:
         
     | 
| 
      
 9 
     | 
    
         
            +
            #
         
     | 
| 
      
 10 
     | 
    
         
            +
            # The above copyright notice and this permission notice shall be included in all
         
     | 
| 
      
 11 
     | 
    
         
            +
            # copies or substantial portions of the Software.
         
     | 
| 
      
 12 
     | 
    
         
            +
            #
         
     | 
| 
      
 13 
     | 
    
         
            +
            # THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
         
     | 
| 
      
 14 
     | 
    
         
            +
            # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
         
     | 
| 
      
 15 
     | 
    
         
            +
            # FITNESS FOR A PARTICULAR PURPOSE AND NONINFINGEMENT. IN NO EVENT SHALL THE
         
     | 
| 
      
 16 
     | 
    
         
            +
            # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
         
     | 
| 
      
 17 
     | 
    
         
            +
            # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
         
     | 
| 
      
 18 
     | 
    
         
            +
            # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
         
     | 
| 
      
 19 
     | 
    
         
            +
            # SOFTWARE.
         
     | 
| 
      
 20 
     | 
    
         
            +
             
     | 
| 
      
 21 
     | 
    
         
            +
            require_relative 'log'
         
     | 
| 
      
 22 
     | 
    
         
            +
             
     | 
| 
      
 23 
     | 
    
         
            +
            # Verbose thread.
         
     | 
| 
      
 24 
     | 
    
         
            +
            # Author:: Yegor Bugayenko (yegor256@gmail.com)
         
     | 
| 
      
 25 
     | 
    
         
            +
            # Copyright:: Copyright (c) 2018 Yegor Bugayenko
         
     | 
| 
      
 26 
     | 
    
         
            +
            # License:: MIT
         
     | 
| 
      
 27 
     | 
    
         
            +
            module Zold
         
     | 
| 
      
 28 
     | 
    
         
            +
              # Verbose thread
         
     | 
| 
      
 29 
     | 
    
         
            +
              class VerboseThread
         
     | 
| 
      
 30 
     | 
    
         
            +
                def initialize(log = Log::Quiet.new)
         
     | 
| 
      
 31 
     | 
    
         
            +
                  @log = log
         
     | 
| 
      
 32 
     | 
    
         
            +
                end
         
     | 
| 
      
 33 
     | 
    
         
            +
             
     | 
| 
      
 34 
     | 
    
         
            +
                def run
         
     | 
| 
      
 35 
     | 
    
         
            +
                  yield
         
     | 
| 
      
 36 
     | 
    
         
            +
                rescue StandardError => e
         
     | 
| 
      
 37 
     | 
    
         
            +
                  @log.error("#{e.class.name}: #{e.message} #{e.backtrace.join("\n\t")}")
         
     | 
| 
      
 38 
     | 
    
         
            +
                  raise e
         
     | 
| 
      
 39 
     | 
    
         
            +
                end
         
     | 
| 
      
 40 
     | 
    
         
            +
              end
         
     | 
| 
      
 41 
     | 
    
         
            +
            end
         
     | 
    
        data/lib/zold/version.rb
    CHANGED
    
    
    
        data/test/node/fake_node.rb
    CHANGED
    
    | 
         @@ -22,6 +22,7 @@ require 'tmpdir' 
     | 
|
| 
       22 
22 
     | 
    
         
             
            require 'webmock/minitest'
         
     | 
| 
       23 
23 
     | 
    
         
             
            require_relative '../../lib/zold/log'
         
     | 
| 
       24 
24 
     | 
    
         
             
            require_relative '../../lib/zold/http'
         
     | 
| 
      
 25 
     | 
    
         
            +
            require_relative '../../lib/zold/verbose_thread'
         
     | 
| 
       25 
26 
     | 
    
         | 
| 
       26 
27 
     | 
    
         
             
            # Fake node.
         
     | 
| 
       27 
28 
     | 
    
         
             
            # Author:: Yegor Bugayenko (yegor256@gmail.com)
         
     | 
| 
         @@ -39,7 +40,7 @@ class FakeNode 
     | 
|
| 
       39 
40 
     | 
    
         
             
                  port = server.addr[1]
         
     | 
| 
       40 
41 
     | 
    
         
             
                  server.close
         
     | 
| 
       41 
42 
     | 
    
         
             
                  node = Thread.new do
         
     | 
| 
       42 
     | 
    
         
            -
                     
     | 
| 
      
 43 
     | 
    
         
            +
                    Zold::VerboseThread.new(@log).run do
         
     | 
| 
       43 
44 
     | 
    
         
             
                      Thread.current.abort_on_exception = true
         
     | 
| 
       44 
45 
     | 
    
         
             
                      home = File.join(dir, 'node-home')
         
     | 
| 
       45 
46 
     | 
    
         
             
                      require_relative '../../lib/zold/commands/node'
         
     | 
| 
         @@ -54,8 +55,6 @@ class FakeNode 
     | 
|
| 
       54 
55 
     | 
    
         
             
                          '--home', home
         
     | 
| 
       55 
56 
     | 
    
         
             
                        ]
         
     | 
| 
       56 
57 
     | 
    
         
             
                      )
         
     | 
| 
       57 
     | 
    
         
            -
                    rescue StandardError => e
         
     | 
| 
       58 
     | 
    
         
            -
                      @log.error(e.message + "\n" + e.backtrace.join("\n\t"))
         
     | 
| 
       59 
58 
     | 
    
         
             
                    end
         
     | 
| 
       60 
59 
     | 
    
         
             
                  end
         
     | 
| 
       61 
60 
     | 
    
         
             
                  home = URI("http://localhost:#{port}/")
         
     | 
    
        data/test/node/test_farm.rb
    CHANGED
    
    | 
         @@ -28,7 +28,7 @@ class FarmTest < Minitest::Test 
     | 
|
| 
       28 
28 
     | 
    
         
             
              def test_makes_best_score_in_background
         
     | 
| 
       29 
29 
     | 
    
         
             
                farm = Zold::Farm.new('NOPREFIX@ffffffffffffffff')
         
     | 
| 
       30 
30 
     | 
    
         
             
                farm.start('localhost', 80, threads: 4, strength: 2)
         
     | 
| 
       31 
     | 
    
         
            -
                sleep 1 while farm.best.empty? || farm.best[0].value.zero?
         
     | 
| 
      
 31 
     | 
    
         
            +
                sleep 0.1 while farm.best.empty? || farm.best[0].value.zero?
         
     | 
| 
       32 
32 
     | 
    
         
             
                assert(farm.best[0].value > 0)
         
     | 
| 
       33 
33 
     | 
    
         
             
                farm.stop
         
     | 
| 
       34 
34 
     | 
    
         
             
              end
         
     | 
    
        data/test/test_tax.rb
    CHANGED
    
    | 
         @@ -47,7 +47,7 @@ class TestTax < Minitest::Test 
     | 
|
| 
       47 
47 
     | 
    
         
             
                    )
         
     | 
| 
       48 
48 
     | 
    
         
             
                  )
         
     | 
| 
       49 
49 
     | 
    
         
             
                  tax = Zold::Tax.new(wallet)
         
     | 
| 
       50 
     | 
    
         
            -
                  assert(tax.debt > Zold::Amount.new(coins:  
     | 
| 
      
 50 
     | 
    
         
            +
                  assert(tax.debt > Zold::Amount.new(coins: 1_006_523_000))
         
     | 
| 
       51 
51 
     | 
    
         
             
                  assert(tax.debt < Zold::Amount.new(coins: 1_006_524_999))
         
     | 
| 
       52 
52 
     | 
    
         
             
                end
         
     | 
| 
       53 
53 
     | 
    
         
             
              end
         
     | 
    
        metadata
    CHANGED
    
    | 
         @@ -1,7 +1,7 @@ 
     | 
|
| 
       1 
1 
     | 
    
         
             
            --- !ruby/object:Gem::Specification
         
     | 
| 
       2 
2 
     | 
    
         
             
            name: zold
         
     | 
| 
       3 
3 
     | 
    
         
             
            version: !ruby/object:Gem::Version
         
     | 
| 
       4 
     | 
    
         
            -
              version: 0.10. 
     | 
| 
      
 4 
     | 
    
         
            +
              version: 0.10.11
         
     | 
| 
       5 
5 
     | 
    
         
             
            platform: ruby
         
     | 
| 
       6 
6 
     | 
    
         
             
            authors:
         
     | 
| 
       7 
7 
     | 
    
         
             
            - Yegor Bugayenko
         
     | 
| 
         @@ -327,6 +327,7 @@ files: 
     | 
|
| 
       327 
327 
     | 
    
         
             
            - lib/zold/signature.rb
         
     | 
| 
       328 
328 
     | 
    
         
             
            - lib/zold/tax.rb
         
     | 
| 
       329 
329 
     | 
    
         
             
            - lib/zold/txn.rb
         
     | 
| 
      
 330 
     | 
    
         
            +
            - lib/zold/verbose_thread.rb
         
     | 
| 
       330 
331 
     | 
    
         
             
            - lib/zold/version.rb
         
     | 
| 
       331 
332 
     | 
    
         
             
            - lib/zold/wallet.rb
         
     | 
| 
       332 
333 
     | 
    
         
             
            - lib/zold/wallets.rb
         
     |