summaryrefslogtreecommitdiff
path: root/service
diff options
context:
space:
mode:
Diffstat (limited to 'service')
-rw-r--r--service/test/reactor/concurrent_logins.rb63
1 files changed, 50 insertions, 13 deletions
diff --git a/service/test/reactor/concurrent_logins.rb b/service/test/reactor/concurrent_logins.rb
index 0af2c5b7..38bdac5f 100644
--- a/service/test/reactor/concurrent_logins.rb
+++ b/service/test/reactor/concurrent_logins.rb
@@ -5,31 +5,68 @@
# -ruby
# -pre-created users
#
-# This can be run with `ruby blocking_spawner <x>`
+# This can be run with `ruby concurrent_logins.rb <x>`
# where x is the number of users you want to login.
#
# It was created to measure login times internally on the application with
# varying number of users
+require 'pry'
USER_PATTERN = "loadtest%d"
PASSWORD_PATTERN = "password_%d"
COUNT = ARGV[0].to_i
-def curl_command(index)
- username = USER_PATTERN % [index]
- password = PASSWORD_PATTERN % [index]
- "curl --silent -X POST --data 'username=#{username}&password=#{password}' --cookie 'XSRF-TOKEN: blablabla' --header 'X-Requested-With: XMLHttpRequest' --header 'X-XSRF-TOKEN: blablabla' http://localhost:3333/login"
+def header_options
+ "--header 'X-Requested-With: XMLHttpRequest' --header 'X-XSRF-TOKEN: blablabla'"
end
-ts = (1...(1+COUNT)).map do |ix|
- t = Thread.new do
- time = Time.now()
- `#{curl_command(ix)}`
- puts "Request time: #{Time.now() - time}"
+def cookies
+ "--cookie 'XSRF-TOKEN: blablabla'"
+end
+
+def curl_command
+ "curl --silent"
+end
+
+def login_command(user_index, username, password)
+ FileUtils.rm "/tmp/user#{user_index}.cookie", force: true
+ "#{curl_command} -X POST --data 'username=#{username}&password=#{password}' --cookie-jar /tmp/user#{user_index}.cookie -w '%{http_code}|%{time_total}' --output '/dev/null' #{cookies} #{header_options} http://localhost:3333/login"
+end
+
+def check_inbox(user_index)
+ "#{curl_command} --cookie /tmp/user#{user_index}.cookie http://localhost:3333"
+end
+
+def complete_login(user_index, user, password)
+ start = Time.now
+ login_response = `#{login_command(user_index, user, password)}`
+ status_code, total_time = login_response.split("|")
+ puts "Login request #{total_time}"
+ if status_code.to_i == 200
+ interstitial = Time.now
+ begin
+ inbox = `#{check_inbox(user_index)}`
+ end until /compose-trigger/.match(inbox)
+ puts "Login loading #{sprintf('%.3f',Time.now - interstitial)}"
+ puts "Login total #{sprintf('%.3f',Time.now - start)}"
+ else
+ puts "Login failed with #{status_code} #{sprintf('%.3f',Time.now - start)}"
+ end
+end
+
+def multi_login
+ ts = (1...(1+COUNT)).map do |user_index|
+ t = Thread.new do
+ username = USER_PATTERN % [user_index]
+ password = PASSWORD_PATTERN % [user_index]
+ complete_login(user_index, username, password)
+ end
+ sleep 1
+ t
end
- sleep 1
- t
+
+ ts.each(&:join)
end
-ts.each(&:join)
+multi_login