mirror of
https://github.com/we-promise/sure.git
synced 2026-04-07 22:34:47 +00:00
* First cut of smallest rebrand, pending icons * Leave SQL schema tokens/user names the same for now * First batch of logos * Release notes/what's new * /releases missing * redirect_uri for sureapp:// * Padded logo * Test the correct /releases URL * Missed a few mobile URIs * Some icons/asssets from /website/ repo * Seed/sample data user @sure.local now * New screenshot * Want to keep their legal "boilerplate" from the upstream repo
38 lines
1.1 KiB
Ruby
38 lines
1.1 KiB
Ruby
# Must be in root of repo for derailed_benchmarks to read the benchmark file
|
|
|
|
require 'bundler'
|
|
Bundler.setup
|
|
|
|
require 'derailed_benchmarks'
|
|
require 'derailed_benchmarks/tasks'
|
|
|
|
# Custom auth helper for Maybe's session-based authentication
|
|
class CustomAuth < DerailedBenchmarks::AuthHelper
|
|
def setup
|
|
# No setup needed
|
|
end
|
|
|
|
def call(env)
|
|
# Make sure this user is created in the DB with realistic data before running benchmarks
|
|
user = User.find_by!(email: "user@sure.local")
|
|
|
|
Rails.logger.debug "Found user for benchmarking: #{user.email}"
|
|
|
|
# Mimic the way Rails handles browser cookies
|
|
session = user.sessions.create!
|
|
key_generator = Rails.application.key_generator
|
|
secret = key_generator.generate_key('signed cookie')
|
|
verifier = ActiveSupport::MessageVerifier.new(secret)
|
|
signed_value = verifier.generate(session.id)
|
|
|
|
env['HTTP_COOKIE'] = "session_token=#{signed_value}"
|
|
|
|
Rails.logger.debug "Setting up session for user: #{user.email}"
|
|
|
|
app.call(env)
|
|
end
|
|
end
|
|
|
|
# Tells derailed_benchmarks to use our custom auth helper
|
|
DerailedBenchmarks.auth = CustomAuth.new
|