lib/benchmark/http/command/spider.rb in benchmark-http-0.15.1 vs lib/benchmark/http/command/spider.rb in benchmark-http-0.16.0

- old
+ new

@@ -1,25 +1,10 @@ -# Copyright, 2018, by Samuel G. D. Williams. <http://www.codeotaku.com> -# -# Permission is hereby granted, free of charge, to any person obtaining a copy -# of this software and associated documentation files (the "Software"), to deal -# in the Software without restriction, including without limitation the rights -# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -# copies of the Software, and to permit persons to whom the Software is -# furnished to do so, subject to the following conditions: -# -# The above copyright notice and this permission notice shall be included in -# all copies or substantial portions of the Software. -# -# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN -# THE SOFTWARE. +# frozen_string_literal: true +# Released under the MIT License. +# Copyright, 2018-2022, by Samuel Williams. + require_relative '../spider' require 'async/await' require 'samovar' @@ -40,11 +25,11 @@ end many :urls, "One or more hosts to benchmark" def log(method, url, response) - Console.logger.call(self, severity: (response.failure? ? :warn : :info)) do |buffer| + Console.logger.public_send(response.failure? ? :warn : :info, self) do |buffer| buffer.puts "#{method} #{url} -> #{response.version} #{response.status} (#{response.body&.length || 'unspecified'} bytes)" response.headers.each do |key, value| buffer.puts "\t#{key}: #{value}" end if @options[:headers] @@ -54,10 +39,10 @@ sync def call spider = HTTP::Spider.new(depth: @options[:depth]) statistics = spider.call(@urls, &self.method(:log)) - statistics.print + Console.logger.info(self, statistics: statistics) return statistics end end end