Sha256: 65969ba48c66547b54b885e0e7269fdb564e068795884268aea6dc667f36a6fe
Contents?: true
Size: 1.63 KB
Versions: 3
Compression:
Stored size: 1.63 KB
Contents
#!/usr/bin/env ruby # frozen_string_literal: true require 'bundler/setup' require 'tmpdir' require 'benchmark/ips' revision = %x(git rev-parse HEAD).rstrip master_revision = %x(git rev-parse origin/master).rstrip branch = if revision == master_revision 'master' else %x(git rev-parse --abbrev-ref HEAD).rstrip end intermediate_results_filename = "#{Dir.tmpdir}/statsd-instrument-benchmarks/#{File.basename($PROGRAM_NAME)}" FileUtils.mkdir_p(File.dirname(intermediate_results_filename)) ENV['ENV'] = "development" require 'statsd-instrument' StatsD.logger = Logger.new(File::NULL) report = Benchmark.ips do |bench| bench.report("StatsD metrics to /dev/null log (branch: #{branch}, sha: #{revision[0, 7]})") do StatsD.increment('StatsD.increment', 10, sample_rate: 15) StatsD.measure('StatsD.measure') { 1 + 1 } StatsD.gauge('StatsD.gauge', 12.0, tags: ["foo:bar", "quc"]) StatsD.set('StatsD.set', 'value', tags: { foo: 'bar', baz: 'quc' }) if StatsD.singleton_client.datagram_builder_class == StatsD::Instrument::DogStatsDDatagramBuilder StatsD.event('StasD.event', "12345") StatsD.service_check("StatsD.service_check", "ok") end end # Store the results in between runs bench.save!(intermediate_results_filename) bench.compare! end if report.entries.length == 1 puts puts "To compare the performance of this revision against another revision (e.g. master)," puts "check out a different branch and run this benchmark script again." elsif ENV['KEEP_RESULTS'] puts puts "The intermediate results have been stored in #{intermediate_results_filename}" else File.unlink(intermediate_results_filename) end
Version data entries
3 entries across 3 versions & 1 rubygems