Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix component locale stubs #159

Merged
merged 4 commits into from
Aug 10, 2016
Merged

Fix component locale stubs #159

merged 4 commits into from
Aug 10, 2016

Conversation

andrewgarner
Copy link
Contributor

@andrewgarner andrewgarner commented Aug 10, 2016

These changes make the stub_shared_component_locales test helper more robust so that it correctly stubs requests originating from a host application.

Currently Slimmer will attempt to make external HTTP requests to fetch locale information when rendering its templates.

Failure/Error: <%= render partial: 'govuk_component/beta_label' %>

WebMock::NetConnectNotAllowedError:
  Real HTTP connections are disabled. Unregistered request: GET http://static.dev.gov.uk/templates/locales with headers {'Accept'=>'*/*; q=0.5, application/xml', 'Accept-Encoding'=>'gzip, deflate', 'User-Agent'=>'Ruby'}

You can stub this request with the following snippet:

stub_request(:get, "http://static.dev.gov.uk/templates/locales").
  with(:headers => {'Accept'=>'*/*; q=0.5, application/xml', 'Accept-Encoding'=>'gzip, deflate', 'User-Agent'=>'Ruby'}).
  to_return(:status => 200, :body => "", :headers => {})

It also adds an RSpec helper that makes it easy for host applications to configure Slimmer correctly under test.

The headers sent are not important in this context. We want to stub
all requests to these resources regardless of the headers sent.
Adds a helper that configures slimmer to behave correctly in a test environment.
@andrewgarner andrewgarner force-pushed the fix-component-locale-stubs branch from adf25c8 to bdc2f88 Compare August 10, 2016 07:24
@gpeng gpeng merged commit 64f8c84 into master Aug 10, 2016
@gpeng gpeng deleted the fix-component-locale-stubs branch August 10, 2016 08:27
tijmenb added a commit to alphagov/finder-frontend that referenced this pull request Feb 27, 2017
Full changelog:

# 10.1.3

* Fix memory leak in components

# 10.1.2

* Bugfix for request URI's encoded as ASCII

# 10.1.1

* Bugfix for caching behaviour

# 10.1.0

* Use `Rails.cache` as the cache for templates, locales and components.
You can
remove `config.slimmer.use_cache` for your application, as you can no
longer
opt-out of caching.
* Add a `User-Agent` header to all outgoing API requests

# 10.0.0

* Removes the need_id meta tag, which is no longer used.
* Removes the functionality for breadcrumbs, related links and
artefact-powered
metatags.
* Drop support for old Rails & Ruby versions. This gem now supports
Rails 4.2 and 5.X
on Ruby 2.1 and 2.2.
* Renames `Slimmer::SharedTemplates` to `Slimmer::GovukComponents`

# 9.6.0

* Adds an 'inside header inserter' processor which allows an
application to
inject a block of HTML after the logo by including a .inside-header
element
in their application’s output.
(PR #167 alphagov/slimmer#167)

* Remove `MetaViewportRemover` processor as it is no longer used.
(PR #166 alphagov/slimmer#166)

# 9.5.0

* Adds a Cucumber helper that makes it easy for host applications to
configure Slimmer correctly under test.

(PR #162 alphagov/slimmer#162)

# 9.4.0

* Adds an RSpec helper that makes it easy for host applications to
configure Slimmer correctly under test.

Fixes `stub_shared_component_locales` helper to correctly stub HTTP
requests to fetch locale information when rendering its templates.

(PR #159 alphagov/slimmer#159)

# 9.3.2

* Bugfix: Over time, the I18n backend would be chained in each request,
causing the stack to grow too large and use too much memory

(PR #157 alphagov/slimmer#157)

# 9.3.1

* Allows frontend apps to stub component locales for example

```ruby
class ActiveSupport::TestCase
include Slimmer::TestHelpers::SharedTemplates

def setup
stub_shared_component_locales
end
end
```

(PR #155 alphagov/slimmer#155)

# 9.3.0

* Integrates translations from GOVUK Components to be used in
applications

When including `Slimmer::SharedComponents`, the I18nBackend will be
chained to `Slimmer::I18nBackend` allowing translations in `static` to
work in the frontend applications

(PR #152 alphagov/slimmer#152)

# 9.2.1

* Replaces deprecated `before_filter` calls in shared templates.

# 9.2.0

* Raise a custom `CouldNotRetrieveTemplate` exception when a connection
to the assets server can't be made because of an SSL problem (PR #143).

# 9.1.0

* Allow applications to request components using full or partial
component
paths, eg "name", "name.raw" and "name.raw.html.erb". This allows
components to be nested within other components.
fofr added a commit to alphagov/manuals-frontend that referenced this pull request Apr 6, 2017
* Fix memory leak with components: alphagov/slimmer#191
* Stub locale requests: alphagov/slimmer#159
fofr added a commit to alphagov/manuals-frontend that referenced this pull request Apr 6, 2017
* Fix memory leak with components: alphagov/slimmer#191
* Stub locale requests: alphagov/slimmer#159
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants