I've written a plugin for Ruby on Rails that allows you to test SSL-dependent application behavior that is driven by the ssl_requirement plugin without the need to install and configure a web server with SSL.
A while back, I wanted the Selenium tests for a Ruby on Rails app I was working on to cover the SSL requirements and allowances of certain controller actions in the system, as defined using functionality provided by the ssl_requirement plugin. I also wanted this SSL-dependent behavior to occur when I was running the application on my local development machines. I had two options:
Get a web server configured with SSL running on my development machines, as well as on the build server.
Patch the logic used by the system to determine if a request is under SSL or not, as well as the logic for constructing a URL under SSL, so that the system can essentially mimic an SSL request without a server configured for SSL.
Since I had multiple Selenium builds on the build server, setting up an SSL server involved adding a host name to the loopback for each build, so that Apache could switch between virtual hosts for the different server ports. I also occasionally ran web servers on my development machines on ports other than the default 3000, as did everyone else on the team, so that we'd all have to go through the setup process for multiple servers on those machines as well. We would need to do all of this work in order to test application logic that, strictly speaking, didn't even require the use of an actual SSL server. Given that the only thing that I was interested in testing was that the requests to certain actions either redirected or didn't, depending on their SSL requirements, all I really needed was to make the application mimic an SSL request.
To mimic an SSL request in conjunction with using the ssl_requirement plugin without an SSL server consisted of patching four things:
ActionController::UrlRewriter#rewrite_url- Provides logic for constructing a URL from options and route parameters
If provided, the
:protocoloption normally serves as the part before the
://in the constructed URL.
The method was patched so that the constructed URL always starts with "http://". If
:protocolis equal to "https", this causes an "ssl" key to be added to the query string of the constructed URL, with a value of "1".
ActionController::AbstractRequest#protocol- Provides the protocol used for the request.
The normal value is one of "http" or "https", depending on whether the request was made under SSL or not.
The method was patched so that it always returns "http".
ActionController::AbstractRequest#ssl?- Indicates whether or not the request was made under SSL.
The normal value is determined by checking if request header
HTTPSis equal to "on" or
HTTP\_X\_FORWARDED_PROTOis equal to "https".
The method was patched so that it checks for a query parameter of "ssl" equal to "1".
SslRequirement#ensure\_proper\_protocol- Used as the
before\_filteron a controller that includes the ssl_requirement plugin module, which causes the redirection to an SSL or non-SSL URL to occur, depending on the requirements defined by the controller.
This method was patched so that, instead of replacing the protocol used on the URL with "http" or "https", it either adds or removes the "ssl" query parameter.
For more information, installation instructions, and so on, please refer to the plugin directly at: