Class: RubyJmeter::ExtendedDSL

Inherits:
DSL
  • Object
show all
Includes:
Parser
Defined in:
lib/ruby-jmeter/dsl.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from Parser

#files, #fill_in, #parse_http_request, #parse_test_type, #parse_uri, #parse_url, #raw_body

Methods inherited from DSL

#access_log_sampler, #aggregate_graph, #aggregate_report, #ajp13_sampler, #assertion_results, #beanshell_assertion, #beanshell_listener, #beanshell_postprocessor, #beanshell_preprocessor, #beanshell_sampler, #beanshell_timer, #bsf_assertion, #bsf_listener, #bsf_postprocessor, #bsf_preprocessor, #bsf_sampler, #bsf_timer, #compare_assertion, #comparison_assertion_visualizer, #constant_timer, #counter, #cssjquery_extractor, #csv_data_set_config, #debug_postprocessor, #debug_sampler, #distribution_graphalpha, #duration_assertion, #foreach_controller, #ftp_request, #ftp_request_defaults, #gaussian_random_timer, #generate_summary_results, #graph_results, #html_assertion, #html_link_parser, #html_parameter_mask, #http_authorization_manager, #http_request, #http_url_rewriting_modifier, #if_controller, #include_controller, #java_request, #java_request_defaults, #jdbc_connection_configuration, #jdbc_postprocessor, #jdbc_preprocessor, #jdbc_request, #jms_pointtopoint, #jms_publisher, #jms_subscriber, #jsr223_assertion, #jsr223_listener, #jsr223_postprocessor, #jsr223_preprocessor, #jsr223_sampler, #jsr223_timer, #junit_request, #keystore_configuration, #ldap_extended_request, #ldap_extended_request_defaults, #ldap_request, #ldap_request_defaults, #login_config_element, #mail_reader_sampler, #mailer_visualizer, #md5hex_assertion, #monitor_results, #once_only_controller, #os_process_sampler, #poisson_random_timer, #random_controller, #random_order_controller, #random_variable, #recording_controller, #regex_user_parameters, #regular_expression_extractor, #response_time_graph, #result_status_action_handler, #runtime_controller, #save_responses_to_a_file, #simple_config_element, #simple_controller, #simple_data_writer, #smime_assertion, #smtp_sampler, #spline_visualizer, #summary_report, #switch_controller, #synchronizing_timer, #tcp_sampler, #tcp_sampler_config, #test_action, #test_fragment, #test_plan, #uniform_random_timer, #view_results_in_table, #view_results_tree, #while_controller, #xml_assertion, #xml_schema_assertion, #xpath_assertion, #xpath_extractor

Constructor Details

#initialize(params = {}) ⇒ ExtendedDSL

Returns a new instance of ExtendedDSL.



6
7
8
9
10
11
12
13
14
15
16
17
18
# File 'lib/ruby-jmeter/dsl.rb', line 6

def initialize(params = {})
  @root = Nokogiri::XML(<<-EOF.strip_heredoc)
    <?xml version="1.0" encoding="UTF-8"?>
    <jmeterTestPlan version="1.2" properties="2.8" jmeter="2.13" ruby-jmeter="2.13.0">
    <hashTree>
    </hashTree>
    </jmeterTestPlan>
  EOF
  node = RubyJmeter::TestPlan.new(params)

  @current_node = @root.at_xpath('//jmeterTestPlan/hashTree')
  @current_node = attach_to_last(node)
end

Instance Attribute Details

#rootObject

Returns the value of attribute root.



4
5
6
# File 'lib/ruby-jmeter/dsl.rb', line 4

def root
  @root
end

Instance Method Details

#active_threads_over_time(params = {}, &block) ⇒ Object Also known as: active_threads



507
508
509
510
# File 'lib/ruby-jmeter/dsl.rb', line 507

def active_threads_over_time(params = {}, &block)
  node = RubyJmeter::Plugins::ActiveThreadsOverTime.new(params)
  attach_node(node, &block)
end

#composite_graph(name, params = {}, &block) ⇒ Object Also known as: composite



500
501
502
503
# File 'lib/ruby-jmeter/dsl.rb', line 500

def composite_graph(name, params = {}, &block)
  node = RubyJmeter::Plugins::CompositeGraph.new(name, params)
  attach_node(node, &block)
end

#console_status_logger(name = 'Console Status Logger', params = {}, &block) ⇒ Object Also known as: console



451
452
453
454
# File 'lib/ruby-jmeter/dsl.rb', line 451

def console_status_logger(name = 'Console Status Logger', params = {}, &block)
  node = RubyJmeter::Plugins::ConsoleStatusLogger.new(name, params)
  attach_node(node, &block)
end

#constant_throughput_timer(params, &block) ⇒ Object Also known as: ConstantThroughputTimer



390
391
392
393
394
395
396
397
# File 'lib/ruby-jmeter/dsl.rb', line 390

def constant_throughput_timer(params, &block)
  params[:value] ||= params[:throughput] || 0.0

  node = RubyJmeter::ConstantThroughputTimer.new(params)
  node.doc.xpath('.//value').first.content = params[:value].to_f

  attach_node(node, &block)
end

#delete(*args, &block) ⇒ Object



138
139
140
141
142
143
144
145
146
# File 'lib/ruby-jmeter/dsl.rb', line 138

def delete(*args, &block)
  params = args.shift || {}
  params = { url: params }.merge(args.shift || {}) if params.class == String
  params[:method] ||= 'DELETE'
  params[:name] ||= params[:url]
  parse_http_request(params)
  node = RubyJmeter::HttpRequest.new(params)
  attach_node(node, &block)
end

#dummy_sampler(name = 'Dummy Sampler', params = {}, &block) ⇒ Object Also known as: dummy



465
466
467
468
# File 'lib/ruby-jmeter/dsl.rb', line 465

def dummy_sampler(name = 'Dummy Sampler', params = {}, &block)
  node = RubyJmeter::Plugins::DummySampler.new(name, params)
  attach_node(node, &block)
end

#exists(variable, &block) ⇒ Object



250
251
252
253
254
255
256
257
# File 'lib/ruby-jmeter/dsl.rb', line 250

def exists(variable, &block)
  params ||= {}
  params[:condition] = "\"${#{variable}}\" != \"\\${#{variable}}\""
  params[:useExpression] = false
  params[:name] = "if ${#{variable}}"
  node = RubyJmeter::IfController.new(params)
  attach_node(node, &block)
end

#extract(params, &block) ⇒ Object Also known as: web_reg_save_param



356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
# File 'lib/ruby-jmeter/dsl.rb', line 356

def extract(params, &block)
  node = if params[:regex]
    params[:refname] = params[:name]
    params[:regex] = params[:regex] #CGI.escapeHTML
    params[:template] = params[:template] || "$1$"
    RubyJmeter::RegularExpressionExtractor.new(params)
  elsif params[:xpath]
    params[:refname] = params[:name]
    params[:xpathQuery] = params[:xpath]
    RubyJmeter::XpathExtractor.new(params)
  elsif params[:json]
    params[:VAR] = params[:name]
    params[:JSONPATH] = params[:json]
    RubyJmeter::Plugins::JsonPathExtractor.new(params)
  elsif params[:css]
    params[:refname] = params[:name]
    params[:expr] = params[:css]
    RubyJmeter::CssjqueryExtractor.new(params)
  end
  attach_node(node, &block)
end

#flood(token, params = {}) ⇒ Object Also known as: grid



573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
# File 'lib/ruby-jmeter/dsl.rb', line 573

def flood(token, params = {})
  if params[:region] == 'local'
    logger.info 'Starting test ...'
    params[:started] = Time.now
    run params
    params[:stopped] = Time.now
    logger.info 'Completed test ...'
    logger.debug 'Uploading results ...' if params[:debug]
  end
  RestClient.proxy = params[:proxy] if params[:proxy]
  begin
    file = Tempfile.new(['jmeter', '.jmx'])
    file.write(doc.to_xml(:indent => 2))
    file.rewind

    flood_files = {
      file: File.new("#{file.path}", 'rb')
    }

    if params[:files]
      flood_files.merge!(Hash[params[:files].map.with_index { |value, index| [index, File.new(value, 'rb')] }])
      params.delete(:files)
    end

    response = RestClient.post "#{params[:endpoint] ? params[:endpoint] : 'https://api.flood.io'}/floods?auth_token=#{token}",
    {
      :flood => {
        :tool => 'jmeter',
        :url => params[:url],
        :name => params[:name],
        :notes => params[:notes],
        :tag_list => params[:tag_list],
        :threads => params[:threads],
        :rampup => params[:rampup],
        :duration => params[:duration],
        :override_hosts => params[:override_hosts],
        :override_parameters => params[:override_parameters],
        # specials for API
        :started => params[:started],
        :stopped => params[:stopped]
      },
      :flood_files => flood_files,
      :results => (File.new("#{params[:jtl] ? params[:jtl] : 'jmeter.jtl'}", 'rb') if params[:region] == 'local'),
      :region => params[:region],
      :multipart => true,
      :content_type => 'application/octet-stream'
    }.merge(params)
    if response.code == 201
      logger.info "Flood results at: #{JSON.parse(response)["permalink"]}"
    else
      logger.fatal "Sorry there was an error: #{JSON.parse(response)["error"]}"
    end
  rescue => e
    logger.fatal "Sorry there was an error: #{JSON.parse(e.response)["error"]}"
  end
end

#get(*args, &block) ⇒ Object Also known as: visit

HTTP Samplers



114
115
116
117
118
119
120
121
122
# File 'lib/ruby-jmeter/dsl.rb', line 114

def get(*args, &block)
  params = args.shift || {}
  params = { url: params }.merge(args.shift || {}) if params.class == String
  params[:method] ||= 'GET'
  params[:name] ||= params[:url]
  parse_http_request(params)
  node = RubyJmeter::HttpRequest.new(params)
  attach_node(node, &block)
end

#head(*args, &block) ⇒ Object



168
169
170
171
172
173
174
175
176
# File 'lib/ruby-jmeter/dsl.rb', line 168

def head(*args, &block)
  params = args.shift || {}
  params = { url: params }.merge(args.shift || {}) if params.class == String
  params[:method] ||= 'HEAD'
  params[:name] ||= params[:url]
  parse_http_request(params)
  node = RubyJmeter::HttpRequest.new(params)
  attach_node(node, &block)
end

#http_cache_manager(params = {}, &block) ⇒ Object Also known as: cache



49
50
51
52
# File 'lib/ruby-jmeter/dsl.rb', line 49

def http_cache_manager(params = {}, &block)
  params[:clearEachIteration] = true if params.keys.include? :clear_each_iteration
  super
end


42
43
44
45
# File 'lib/ruby-jmeter/dsl.rb', line 42

def http_cookie_manager(params = {}, &block)
  params[:clearEachIteration] = true if params.keys.include? :clear_each_iteration
  super
end

#http_header_manager(params, &block) ⇒ Object Also known as: header



70
71
72
73
74
75
# File 'lib/ruby-jmeter/dsl.rb', line 70

def http_header_manager(params, &block)
  if params.is_a?(Hash)
    params['Header.name'] = params[:name]
  end
  super
end

#http_request_defaults(params = {}, &block) ⇒ Object Also known as: defaults



32
33
34
35
36
37
38
# File 'lib/ruby-jmeter/dsl.rb', line 32

def http_request_defaults(params = {}, &block)
  params[:image_parser] = true if params.keys.include? :download_resources
  params[:concurrentDwn] = true if params.keys.include? :use_concurrent_pool
  params[:concurrentPool] = params[:use_concurrent_pool] if params.keys.include? :use_concurrent_pool
  params[:embedded_url_re] = params[:urls_must_match] if params.keys.include? :urls_must_match
  super
end

#jmx(params = {}) ⇒ Object



536
537
538
539
# File 'lib/ruby-jmeter/dsl.rb', line 536

def jmx(params = {})
  file(params)
  logger.info "Test plan saved to: #{params[:file]}"
end

#latencies_over_time(name = 'Response Latencies Over Time', params = {}, &block) ⇒ Object



446
447
448
449
# File 'lib/ruby-jmeter/dsl.rb', line 446

def latencies_over_time(name = 'Response Latencies Over Time', params = {}, &block)
  node = RubyJmeter::Plugins::LatenciesOverTime.new(name, params)
  attach_node(node, &block)
end

#loadosophia_uploader(name = "Loadosophia.org Uploader", params = {}, &block) ⇒ Object Also known as: loadosophia



521
522
523
524
# File 'lib/ruby-jmeter/dsl.rb', line 521

def loadosophia_uploader(name = "Loadosophia.org Uploader", params = {}, &block)
  node = RubyJmeter::Plugins::LoadosophiaUploader.new(name, params)
  attach_node(node, &block)
end

#loop_controller(params, &block) ⇒ Object Also known as: Loop



261
262
263
264
# File 'lib/ruby-jmeter/dsl.rb', line 261

def loop_controller(params, &block)
  params[:loops] = params[:count] || 1
  super
end

#module_controller(params, &block) ⇒ Object

Other Elements



304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
# File 'lib/ruby-jmeter/dsl.rb', line 304

def module_controller(params, &block)
  node = RubyJmeter::ModuleController.new(params)

  if params[:test_fragment]
    params[:test_fragment].kind_of?(String) &&
    params[:test_fragment].split('/')
  elsif params[:node_path]
    params[:node_path]
  else
    []
  end.each_with_index do |node_name, index|
    node.doc.at_xpath('//collectionProp') <<
      Nokogiri::XML(<<-EOS.strip_heredoc).children
        <stringProp name="node_#{index}">#{node_name}</stringProp>
      EOS
  end

  attach_node(node, &block)
end

#out(params = {}) ⇒ Object

API Methods



532
533
534
# File 'lib/ruby-jmeter/dsl.rb', line 532

def out(params = {})
  puts doc.to_xml(:indent => 2)
end

#patch(*args, &block) ⇒ Object



158
159
160
161
162
163
164
165
166
# File 'lib/ruby-jmeter/dsl.rb', line 158

def patch(*args, &block)
  params = args.shift || {}
  params = { url: params }.merge(args.shift || {}) if params.class == String
  params[:method] ||= 'PATCH'
  params[:name] ||= params[:url]
  parse_http_request(params)
  node = RubyJmeter::HttpRequest.new(params)
  attach_node(node, &block)
end

#perfmon_collector(name, params = {}, filename = "perfMon.jtl", &block) ⇒ Object Also known as: perfmon



514
515
516
517
# File 'lib/ruby-jmeter/dsl.rb', line 514

def perfmon_collector(name, params = {}, filename="perfMon.jtl", &block)
  node = RubyJmeter::Plugins::PerfmonCollector.new(name, params, filename)
  attach_node(node, &block)
end

#post(*args, &block) ⇒ Object Also known as: submit



126
127
128
129
130
131
132
133
134
# File 'lib/ruby-jmeter/dsl.rb', line 126

def post(*args, &block)
  params = args.shift || {}
  params = { url: params }.merge(args.shift || {}) if params.class == String
  params[:method] ||= 'POST'
  params[:name] ||= params[:url]
  parse_http_request(params)
  node = RubyJmeter::HttpRequest.new(params)
  attach_node(node, &block)
end

#put(*args, &block) ⇒ Object



148
149
150
151
152
153
154
155
156
# File 'lib/ruby-jmeter/dsl.rb', line 148

def put(*args, &block)
  params = args.shift || {}
  params = { url: params }.merge(args.shift || {}) if params.class == String
  params[:method] ||= 'PUT'
  params[:name] ||= params[:url]
  parse_http_request(params)
  node = RubyJmeter::HttpRequest.new(params)
  attach_node(node, &block)
end

#random_timer(delay = 0, range = 0, &block) ⇒ Object Also known as: think_time



380
381
382
383
384
385
386
# File 'lib/ruby-jmeter/dsl.rb', line 380

def random_timer(delay=0, range=0, &block)
  params = {}
  params[:delay] = delay
  params[:range] = range
  node = RubyJmeter::GaussianRandomTimer.new(params)
  attach_node(node, &block)
end

#response_assertion(params = {}, &block) ⇒ Object Also known as: assert, web_reg_find



401
402
403
404
405
406
407
408
409
410
411
412
# File 'lib/ruby-jmeter/dsl.rb', line 401

def response_assertion(params = {}, &block)
  params[:test_type] = parse_test_type(params)
  params['0'] = params.values.first
  node = RubyJmeter::ResponseAssertion.new(params)
  if params[:variable] then
    params['Scope.variable'] = params[:variable]
    node.doc.xpath("//stringProp[@name='Assertion.scope']").first.content = 'variable'
  end
  node.doc.xpath("//stringProp[@name='Assertion.scope']").remove if
    params[:scope] == 'main' || params['scope'] == 'main'
  attach_node(node, &block)
end

#response_codes_per_second(name = 'Response Codes per Second', params = {}, &block) ⇒ Object

JMeter Plugins



421
422
423
424
# File 'lib/ruby-jmeter/dsl.rb', line 421

def response_codes_per_second(name = 'Response Codes per Second', params = {}, &block)
  node = RubyJmeter::Plugins::ResponseCodesPerSecond.new(name, params)
  attach_node(node, &block)
end

#response_times_distribution(name = 'Response Times Distribution', params = {}, &block) ⇒ Object



426
427
428
429
# File 'lib/ruby-jmeter/dsl.rb', line 426

def response_times_distribution(name = 'Response Times Distribution', params = {}, &block)
  node = RubyJmeter::Plugins::ResponseTimesDistribution.new(name, params)
  attach_node(node, &block)
end

#response_times_over_time(name = 'Response Times Over Time', params = {}, &block) ⇒ Object



431
432
433
434
# File 'lib/ruby-jmeter/dsl.rb', line 431

def response_times_over_time(name = 'Response Times Over Time', params = {}, &block)
  node = RubyJmeter::Plugins::ResponseTimesOverTime.new(name, params)
  attach_node(node, &block)
end

#response_times_percentiles(name = 'Response Times Percentiles', params = {}, &block) ⇒ Object



436
437
438
439
# File 'lib/ruby-jmeter/dsl.rb', line 436

def response_times_percentiles(name = 'Response Times Percentiles', params = {}, &block)
  node = RubyJmeter::Plugins::ResponseTimesPercentiles.new(name, params)
  attach_node(node, &block)
end

#run(params = {}) ⇒ Object



549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
# File 'lib/ruby-jmeter/dsl.rb', line 549

def run(params = {})
  file(params)
  logger.warn "Test executing locally ..."
  properties = params.has_key?(:properties) ? build_properties(params[:properties]) : "-q #{File.dirname(__FILE__)}/helpers/jmeter.properties"

  if params[:remote_hosts]
    remote_hosts = params[:remote_hosts]
    remote_hosts = remote_hosts.join(',') if remote_hosts.kind_of?(Array)
    remote_hosts = "-R #{remote_hosts}"
  end

  cmd = "#{params[:path]}jmeter #{"-n" unless params[:gui] } -t #{params[:file]} -j #{params[:log] ? params[:log] : 'jmeter.log' } -l #{params[:jtl] ? params[:jtl] : 'jmeter.jtl' } #{properties} #{remote_hosts}"
  logger.debug cmd if params[:debug]
  Open3.popen2e("#{cmd}") do |stdin, stdout_err, wait_thr|
    while line = stdout_err.gets
      logger.debug line.chomp if params[:debug]
    end

    exit_status = wait_thr.value
    abort "FAILED !!! #{cmd}" unless exit_status.success?
  end
  logger.info "Local Results at: #{params[:jtl] ? params[:jtl] : 'jmeter.jtl'}"
end

#setup_thread_group(*args, &block) ⇒ Object



97
98
99
100
101
102
103
104
105
106
107
108
109
# File 'lib/ruby-jmeter/dsl.rb', line 97

def setup_thread_group(*args, &block)
  params = args.shift || {}
  params = { count: params }.merge(args.shift || {}) if params.class == Fixnum
  params[:num_threads] = params[:count] || 1
  params[:ramp_time] = params[:rampup] || (params[:num_threads]/2.0).ceil
  params[:start_time] = params[:start_time] || Time.now.to_i * 1000
  params[:end_time] = params[:end_time] || Time.now.to_i * 1000
  params[:duration] ||= 60
  params[:continue_forever] ||= false
  params[:loops] = -1 if params[:continue_forever]
  node = RubyJmeter::SetupThreadGroup.new(params)
  attach_node(node, &block)
end

#soapxmlrpc_request(params, &block) ⇒ Object Also known as: soap

Other Samplers



223
224
225
226
# File 'lib/ruby-jmeter/dsl.rb', line 223

def soapxmlrpc_request(params, &block)
  params[:method] ||= 'POST'
  super
end

#stepping_thread_group(params = {}, &block) ⇒ Object Also known as: step



472
473
474
475
# File 'lib/ruby-jmeter/dsl.rb', line 472

def stepping_thread_group(params = {}, &block)
  node = RubyJmeter::Plugins::SteppingThreadGroup.new(params)
  attach_node(node, &block)
end

#test_data(*args, &block) ⇒ Object



193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
# File 'lib/ruby-jmeter/dsl.rb', line 193

def test_data(*args, &block)
  params = args.shift || {}
  params = { key: params.to_s }.merge(args.shift || {}) if(params.class == String || params.class == Symbol)
  params[:command] ||= 'SRANDMEMBER'
  params[:name] ||= 'testdata'
  params[:regex] ||= '"(.+?)"'
  params[:match_num] ||= -1
  params[:default] ||= ''

  params[:host] ||= '54.252.206.143'

  params[:url] = params[:key] if URI.parse(URI::encode(params[:key])).scheme

  params[:url] = if params[:host]
    "http://#{params[:host]}/data/#{params[:command]}/#{params[:key]}?type=text"
  end

  params[:url] = 'http://54.252.206.143/data/' if params[:stub]

  get name: '__testdata', url: params[:url] do
    extract name: params[:name],
      regex: params[:regex],
      match_num: params[:match_num],
      default: params[:default]
  end
end

#thread_group(*args, &block) ⇒ Object Also known as: threads



81
82
83
84
85
86
87
88
89
90
91
92
93
# File 'lib/ruby-jmeter/dsl.rb', line 81

def thread_group(*args, &block)
  params = args.shift || {}
  params = { count: params }.merge(args.shift || {}) if params.class == Fixnum
  params[:num_threads] = params[:count] || 1
  params[:ramp_time] = params[:rampup] || (params[:num_threads]/2.0).ceil
  params[:start_time] = params[:start_time] || Time.now.to_i * 1000
  params[:end_time] = params[:end_time] || Time.now.to_i * 1000
  params[:duration] ||= 60
  params[:continue_forever] ||= false
  params[:loops] = -1 if params[:continue_forever]
  node = RubyJmeter::ThreadGroup.new(params)
  attach_node(node, &block)
end

#throughput_controller(params, &block) ⇒ Object Also known as: Throughput



268
269
270
271
272
273
274
275
276
# File 'lib/ruby-jmeter/dsl.rb', line 268

def throughput_controller(params, &block)
  params[:style] = 1 if params[:percent]
  params[:maxThroughput] = params[:total] || params[:percent] || 1

  node = RubyJmeter::ThroughputController.new(params)
  node.doc.xpath(".//FloatProperty/value").first.content = params[:maxThroughput].to_f

  attach_node(node, &block)
end

#throughput_shaper(name = 'Throughput Shaping Timer', steps = [], params = {}, &block) ⇒ Object Also known as: shaper



458
459
460
461
# File 'lib/ruby-jmeter/dsl.rb', line 458

def throughput_shaper(name = 'Throughput Shaping Timer', steps=[], params = {}, &block)
  node = RubyJmeter::Plugins::ThroughputShapingTimer.new(name, steps)
  attach_node(node, &block)
end

#to_docObject



545
546
547
# File 'lib/ruby-jmeter/dsl.rb', line 545

def to_doc
  doc.clone
end

#to_xmlObject



541
542
543
# File 'lib/ruby-jmeter/dsl.rb', line 541

def to_xml
  doc.to_xml(:indent => 2)
end

#transaction_controller(*args, &block) ⇒ Object Also known as: transaction

Controllers



239
240
241
242
243
244
245
246
# File 'lib/ruby-jmeter/dsl.rb', line 239

def transaction_controller(*args, &block)
  params = args.shift || {}
  params = { name: params }.merge(args.shift || {}) if params.class == String
  params[:parent] = params[:parent] || false
  params[:includeTimers] = params[:include_timers] || false
  node = RubyJmeter::TransactionController.new(params)
  attach_node(node, &block)
end

#transactions_per_second(name = 'Transactions per Second', params = {}, &block) ⇒ Object



441
442
443
444
# File 'lib/ruby-jmeter/dsl.rb', line 441

def transactions_per_second(name = 'Transactions per Second', params = {}, &block)
  node = RubyJmeter::Plugins::TransactionsPerSecond.new(name, params)
  attach_node(node, &block)
end

#ultimate_thread_group(params = {}, &block) ⇒ Object Also known as: ultimate



479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
# File 'lib/ruby-jmeter/dsl.rb', line 479

def ultimate_thread_group(params = {}, &block)
  node = RubyJmeter::Plugins::UltimateThreadGroup.new(params)

  params.each_with_index do |group, index|
    node.doc.at_xpath('//collectionProp') <<
      Nokogiri::XML(<<-EOS.strip_heredoc).children
        <collectionProp name="index">
          <stringProp name="#{group[:start_threads]}">#{group[:start_threads]}</stringProp>
          <stringProp name="#{group[:initial_delay]}">#{group[:initial_delay]}</stringProp>
          <stringProp name="#{group[:start_time]}">#{group[:start_time]}</stringProp>
          <stringProp name="#{group[:hold_time]}">#{group[:hold_time]}</stringProp>
          <stringProp name="#{group[:stop_time]}">#{group[:stop_time]}</stringProp>
        </collectionProp>
      EOS
  end

  attach_node(node, &block)
end

#user_defined_variables(params, &block) ⇒ Object Also known as: variables

Config Elements



23
24
25
26
27
28
# File 'lib/ruby-jmeter/dsl.rb', line 23

def user_defined_variables(params, &block)
  if params.is_a?(Hash)
    params['Argument.name'] = params[:name]
  end
  super
end

#user_parameters(params, &block) ⇒ Object



324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
# File 'lib/ruby-jmeter/dsl.rb', line 324

def user_parameters(params, &block)
  if params.is_a?(Hash)
    params['Argument.name'] = params[:name]
  end

  params[:names] = Nokogiri::XML::Builder.new do |b|
    b.builder do
      params[:names].each do |name|
        b.stringProp name, name: name
      end
    end
  end

  params[:thread_values] = Nokogiri::XML::Builder.new do |b|
    b.builder do
      params[:thread_values].map do |user, values|
        b.collectionProp name: user do
          values.each_with_index.map do |value, index|
            b.stringProp value, name: index
          end
        end
      end
    end
  end

  super
end

#with_browser(device) ⇒ Object



61
62
63
64
65
66
67
68
# File 'lib/ruby-jmeter/dsl.rb', line 61

def with_browser(device)
  http_header_manager name: 'User-Agent',
                      value: RubyJmeter::UserAgent.new(device).string
  http_header_manager [
    { name: 'Accept-Encoding', value: 'gzip,deflate,sdch' },
    { name: 'Accept', value: 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8' }
  ]
end

#with_gzipObject



183
184
185
186
# File 'lib/ruby-jmeter/dsl.rb', line 183

def with_gzip
  http_header_manager name: 'Accept-Encoding',
                      value: 'gzip, deflate'
end

#with_jsonObject



188
189
190
191
# File 'lib/ruby-jmeter/dsl.rb', line 188

def with_json
  http_header_manager name: 'Accept',
                      value: 'text/html, application/xhtml+xml, application/xml;q=0.9, */*;q=0.8, application/json'
end

#with_user_agent(device) ⇒ Object



56
57
58
59
# File 'lib/ruby-jmeter/dsl.rb', line 56

def with_user_agent(device)
  http_header_manager name: 'User-Agent',
                      value: RubyJmeter::UserAgent.new(device).string
end

#with_xhrObject



178
179
180
181
# File 'lib/ruby-jmeter/dsl.rb', line 178

def with_xhr
  http_header_manager name: 'X-Requested-With',
                      value: 'XMLHttpRequest'
end