| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 | # frozen_string_literal: truerequire 'bundler/setup'require 'time'MAX_PK = 10_000ID_RANGE = (1..MAX_PK).freezeALL_IDS = ID_RANGE.to_aQUERIES_MIN = 1QUERIES_MAX = 500SERVER_STRING =  if defined?(PhusionPassenger)    'passenger'  elsif defined?(Puma)    'puma'  elsif defined?(Unicorn)    'unicorn'  elsif defined?(Agoo)    'agoo'  endBundler.require(:default) # Load core modulesdef connect(dbtype)  Bundler.require(dbtype) # Load database-specific modules  opts = {    :adapter=>(dbtype == :mysql ? 'mysql2' : 'postgresql'),    :username=>'benchmarkdbuser',    :password=>'benchmarkdbpass',    :host=>'tfb-database',    :database=>'hello_world'  }  # Determine threading/thread pool size and timeout  if defined?(JRUBY_VERSION)    opts[:pool] = (2 * Math.log(Integer(ENV.fetch('MAX_CONCURRENCY')))).floor    opts[:checkout_timeout] = 10  elsif defined?(Puma) && (threads = Puma.cli_config.options.fetch(:max_threads)) > 1    opts[:pool] = (2 * Math.log(threads)).floor    opts[:checkout_timeout] = 10  else    # TODO: ActiveRecord doesn't have a single-threaded mode?    opts[:pool] = 1    opts[:checkout_timeout] = 0  end  ActiveRecord::Base.establish_connection(opts)endconnect ENV.fetch('DBTYPE').to_sym# Define ORM modelsclass World < ActiveRecord::Base  self.table_name = name  alias_attribute(:randomNumber, :randomnumber) \    if connection.adapter_name.downcase.start_with?('postgres')  if connection.adapter_name.downcase.start_with?('mysql')    def self.upsert_all(attributes, on_duplicate: :update, update_only: nil, returning: nil, unique_by: nil, record_timestamps: nil)      # On MySQL Batch updates verification isn't supported yet by TechEmpower.      # https://github.com/TechEmpower/FrameworkBenchmarks/issues/5983      attributes.each do |attrs|        where(id: attrs[:id]).update_all(randomNumber: attrs[:randomNumber])      end    end  endendclass Fortune < ActiveRecord::Base  self.table_name = nameendActiveRecord::Base.connection_handler.clear_active_connections!
 |