baarkerlounger
3 years ago
99 changed files with 9284 additions and 0 deletions
@ -0,0 +1,23 @@
|
||||
.git |
||||
.github |
||||
|
||||
*.log |
||||
log |
||||
|
||||
tmp |
||||
|
||||
storage |
||||
|
||||
public/assets |
||||
.byebug_history |
||||
|
||||
config/master.key |
||||
|
||||
public/packs |
||||
public/packs-test |
||||
node_modules |
||||
vendor/cache |
||||
yarn-debug.log* |
||||
.yarn-integrity |
||||
|
||||
.env |
@ -0,0 +1,19 @@
|
||||
root = true |
||||
|
||||
[*] |
||||
insert_final_newline = true |
||||
trim_trailing_whitespace = true |
||||
max_line_length = 80 |
||||
indent_size = 2 |
||||
indent_style = space |
||||
charset = utf-8 |
||||
end_of_line = lf |
||||
|
||||
[*.py] |
||||
indent_size = 4 |
||||
|
||||
[*.md] |
||||
trim_trailing_whitespace = false |
||||
|
||||
[Makefile] |
||||
indent_style = tab |
@ -0,0 +1,2 @@
|
||||
DB_USERNAME: postgres-user |
||||
DB_PASSWORD: postgres-password |
@ -0,0 +1,142 @@
|
||||
name: 'CI/CD Pipeline' |
||||
|
||||
on: |
||||
push: |
||||
branches: |
||||
- main |
||||
pull_request: |
||||
|
||||
concurrency: 'Beta - Production' |
||||
|
||||
defaults: |
||||
run: |
||||
shell: bash |
||||
|
||||
env: |
||||
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} |
||||
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} |
||||
|
||||
jobs: |
||||
|
||||
test: |
||||
name: Test |
||||
runs-on: ubuntu-latest |
||||
|
||||
services: |
||||
postgres: |
||||
image: postgres:13.3 |
||||
env: |
||||
POSTGRES_PASSWORD: password |
||||
POSTGRES_USER: postgres |
||||
POSTGRES_DB: data_collector |
||||
ports: |
||||
- 5432:5432 |
||||
# needed because the postgres container does not provide a healthcheck |
||||
# tmpfs makes DB faster by using RAM |
||||
options: >- |
||||
--mount type=tmpfs,destination=/var/lib/postgresql/data |
||||
--health-cmd pg_isready |
||||
--health-interval 10s |
||||
--health-timeout 5s |
||||
--health-retries 5 |
||||
env: |
||||
RAILS_ENV: test |
||||
GEMFILE_RUBY_VERSION: 3.0.0 |
||||
DB_HOST: localhost |
||||
DB_DATABASE: data_collector |
||||
DB_USERNAME: postgres |
||||
DB_PASSWORD: password |
||||
|
||||
# Rails verifies the time zone in DB is the same as the time zone of the Rails app |
||||
TZ: "Europe/London" |
||||
|
||||
|
||||
steps: |
||||
- name: Checkout |
||||
uses: actions/checkout@v2 |
||||
|
||||
- name: Set up Ruby |
||||
uses: ruby/setup-ruby@v1 |
||||
with: |
||||
# runs 'bundle install' and caches installed gems automatically |
||||
bundler-cache: true |
||||
working-directory: ./data-collector |
||||
|
||||
- name: Create DB |
||||
working-directory: ./data-collector |
||||
run: | |
||||
bundle exec rake db:prepare |
||||
|
||||
- name: Compile Assets |
||||
working-directory: ./data-collector |
||||
run: | |
||||
bundle exec rake assets:precompile |
||||
|
||||
- name: Run tests |
||||
working-directory: ./data-collector |
||||
run: | |
||||
bundle exec rake |
||||
|
||||
deploy: |
||||
name: Deploy |
||||
runs-on: ubuntu-latest |
||||
environment: 'Beta - Production' |
||||
needs: |
||||
- terraform |
||||
- test |
||||
timeout-minutes: 30 |
||||
env: |
||||
AWS_REGION: eu-west-2 |
||||
ECR_REPOSITORY: container-repository |
||||
ECS_SERVICE: app |
||||
ECS_CLUSTER: ecs-cluster |
||||
CONTAINER_NAME: app # set this to the name of the container in the containerDefinitions section of your task definition |
||||
|
||||
steps: |
||||
- name: Checkout |
||||
uses: actions/checkout@v2 |
||||
|
||||
- name: Configure AWS credentials |
||||
uses: aws-actions/configure-aws-credentials@v1 |
||||
with: |
||||
aws-access-key-id: ${{ env.AWS_ACCESS_KEY_ID }} |
||||
aws-secret-access-key: ${{ env.AWS_SECRET_ACCESS_KEY }} |
||||
aws-region: ${{ env.AWS_REGION }} |
||||
|
||||
- name: Login to Amazon ECR |
||||
id: login-ecr |
||||
uses: aws-actions/amazon-ecr-login@v1 |
||||
|
||||
- name: Build, tag, and push the image to Amazon ECR |
||||
id: build-image |
||||
working-directory: ./data-collector |
||||
env: |
||||
ECR_REGISTRY: ${{ steps.login-ecr.outputs.registry }} |
||||
ECR_REPOSITORY: ${{ env.ECR_REPOSITORY }} |
||||
IMAGE_TAG: ${{ github.sha }} |
||||
run: | |
||||
# Build a docker container and push it to ECR |
||||
docker build -t $ECR_REGISTRY/$ECR_REPOSITORY:$IMAGE_TAG . |
||||
echo "Pushing image to ECR..." |
||||
docker push $ECR_REGISTRY/$ECR_REPOSITORY:$IMAGE_TAG |
||||
echo "::set-output name=image::$ECR_REGISTRY/$ECR_REPOSITORY:$IMAGE_TAG" |
||||
|
||||
- name: Download task definition |
||||
run: | |
||||
aws ecs describe-task-definition --task-definition app --query taskDefinition > task-definition.json |
||||
|
||||
- name: Fill in the new image ID in the Amazon ECS task definition |
||||
id: task-def |
||||
uses: aws-actions/amazon-ecs-render-task-definition@v1 |
||||
with: |
||||
task-definition: task-definition.json |
||||
container-name: ${{ env.CONTAINER_NAME }} |
||||
image: ${{ steps.build-image.outputs.image }} |
||||
|
||||
- name: Deploy Amazon ECS task definition |
||||
uses: aws-actions/amazon-ecs-deploy-task-definition@v1 |
||||
with: |
||||
task-definition: ${{ steps.task-def.outputs.task-definition }} |
||||
service: ${{ env.ECS_SERVICE }} |
||||
cluster: ${{ env.ECS_CLUSTER }} |
||||
wait-for-service-stability: true |
@ -0,0 +1,38 @@
|
||||
# See https://help.github.com/articles/ignoring-files for more about ignoring files. |
||||
# |
||||
# If you find yourself ignoring temporary files generated by your text editor |
||||
# or operating system, you probably want to add a global ignore instead: |
||||
# git config --global core.excludesfile '~/.gitignore_global' |
||||
|
||||
# Ignore bundler config. |
||||
/.bundle |
||||
|
||||
# Ignore all logfiles and tempfiles. |
||||
/log/* |
||||
/tmp/* |
||||
!/log/.keep |
||||
!/tmp/.keep |
||||
|
||||
# Ignore pidfiles, but keep the directory. |
||||
/tmp/pids/* |
||||
!/tmp/pids/ |
||||
!/tmp/pids/.keep |
||||
|
||||
# Ignore uploaded files in development. |
||||
/storage/* |
||||
!/storage/.keep |
||||
|
||||
/public/assets |
||||
.byebug_history |
||||
|
||||
# Ignore master key for decrypting credentials and more. |
||||
/config/master.key |
||||
|
||||
/public/packs |
||||
/public/packs-test |
||||
/node_modules |
||||
/yarn-error.log |
||||
yarn-debug.log* |
||||
.yarn-integrity |
||||
|
||||
.env |
@ -0,0 +1,42 @@
|
||||
# Use this file to configure the Overcommit hooks you wish to use. This will |
||||
# extend the default configuration defined in: |
||||
# https://github.com/brigade/overcommit/blob/master/config/default.yml |
||||
# |
||||
# At the topmost level of this YAML file is a key representing type of hook |
||||
# being run (e.g. pre-commit, commit-msg, etc.). Within each type you can |
||||
# customize each hook, such as whether to only run it on certain files (via |
||||
# `include`), whether to only display output if it fails (via `quiet`), etc. |
||||
# |
||||
# For a complete list of hooks, see: |
||||
# https://github.com/brigade/overcommit/tree/master/lib/overcommit/hook |
||||
# |
||||
# For a complete list of options that you can use to customize hooks, see: |
||||
# https://github.com/brigade/overcommit#configuration |
||||
# |
||||
# Uncomment the following lines to make the configuration take effect. |
||||
gemfile: Gemfile |
||||
verify_signatures: false |
||||
PreCommit: |
||||
BundleCheck: |
||||
enabled: true |
||||
FixMe: |
||||
enabled: true |
||||
keywords: ["FIXME"] |
||||
exclude: |
||||
- .overcommit.yml |
||||
LocalPathsInGemfile: |
||||
enabled: true |
||||
RailsSchemaUpToDate: |
||||
enabled: true |
||||
RuboCop: |
||||
enabled: true |
||||
on_warn: fail |
||||
TrailingWhitespace: |
||||
enabled: true |
||||
exclude: |
||||
- "**/db/structure.sql" |
||||
YamlSyntax: |
||||
enabled: true |
||||
PostCheckout: |
||||
ALL: |
||||
quiet: true |
@ -0,0 +1,20 @@
|
||||
require: |
||||
- rubocop-performance |
||||
- rubocop-rails |
||||
|
||||
inherit_gem: |
||||
rubocop-govuk: |
||||
- config/default.yml |
||||
- config/rails.yml |
||||
|
||||
AllCops: |
||||
Exclude: |
||||
- 'bin/*' |
||||
- 'db/schema.rb' |
||||
- 'node_modules/**/*' |
||||
- 'config/application.rb' |
||||
- 'config/puma.rb' |
||||
- 'vendor/**/*' |
||||
|
||||
Style/Documentation: |
||||
Enabled: false |
@ -0,0 +1,71 @@
|
||||
# Build compilation image |
||||
FROM ruby:3.0.0-alpine as builder |
||||
|
||||
# The application runs from /app |
||||
WORKDIR /app |
||||
|
||||
# Add the timezone as it's not configured by default in Alpine |
||||
RUN apk add --update --no-cache tzdata && \ |
||||
cp /usr/share/zoneinfo/Europe/London /etc/localtime && \ |
||||
echo "Europe/London" > /etc/timezone |
||||
|
||||
# build-base: complication tools for bundle |
||||
# yarn: node package manager |
||||
# postgresql-dev: postgres driver and libraries |
||||
RUN apk add --no-cache build-base yarn postgresql-dev |
||||
|
||||
# Install bundler to run bundle exec |
||||
# This should be the same version as the Gemfile.lock |
||||
RUN gem install bundler:2.2.3 --no-document |
||||
|
||||
# Install gems defined in Gemfile |
||||
COPY .ruby-version Gemfile Gemfile.lock /app/ |
||||
|
||||
RUN bundle config set without "development test" |
||||
ARG BUNDLE_FLAGS="--jobs=4 --no-binstubs --no-cache" |
||||
RUN bundle install ${BUNDLE_FLAGS} |
||||
|
||||
# Install node packages defined in package.json, including webpack |
||||
COPY package.json yarn.lock /app/ |
||||
RUN yarn install --frozen-lockfile |
||||
|
||||
# Copy all files to /app (except what is defined in .dockerignore) |
||||
COPY . /app/ |
||||
|
||||
# Compile assets and run webpack. We set a dummy secret key. |
||||
RUN RAILS_ENV=production bundle exec rails SECRET_KEY_BASE=pickasecuretoken assets:precompile |
||||
|
||||
# Cleanup to save space in the production image |
||||
RUN rm -rf node_modules log tmp && \ |
||||
rm -rf /usr/local/bundle/cache && \ |
||||
rm -rf .env && \ |
||||
find /usr/local/bundle/gems -name "*.c" -delete && \ |
||||
find /usr/local/bundle/gems -name "*.h" -delete && \ |
||||
find /usr/local/bundle/gems -name "*.o" -delete && \ |
||||
find /usr/local/bundle/gems -name "*.html" -delete |
||||
|
||||
# Build runtime image |
||||
FROM ruby:3.0.0-alpine as production |
||||
|
||||
# The application runs from /app |
||||
WORKDIR /app |
||||
|
||||
# Add postgres driver library |
||||
# Add the timezone as it's not configured by default in Alpine |
||||
RUN apk add --update --no-cache libpq tzdata && \ |
||||
cp /usr/share/zoneinfo/Europe/London /etc/localtime && \ |
||||
echo "Europe/London" > /etc/timezone |
||||
|
||||
# Copy files generated in the builder image |
||||
COPY --from=builder /app /app |
||||
COPY --from=builder /usr/local/bundle/ /usr/local/bundle/ |
||||
|
||||
ARG GIT_COMMIT_SHA="UNKNOWN" |
||||
ENV GIT_COMMIT_SHA=${GIT_COMMIT_SHA} |
||||
RUN echo ${GIT_COMMIT_SHA} > ./GIT_COMMIT_SHA |
||||
|
||||
ENV PORT=8080 |
||||
|
||||
EXPOSE ${PORT} |
||||
|
||||
CMD RAILS_ENV=${RAILS_ENV} bundle exec rake db:migrate && bundle exec rails s -e ${RAILS_ENV} -p ${PORT} --binding=0.0.0.0 |
@ -0,0 +1,51 @@
|
||||
# frozen_string_literal: true |
||||
|
||||
source "https://rubygems.org" |
||||
git_source(:github) { |repo| "https://github.com/#{repo}.git" } |
||||
|
||||
ruby "3.0.0" |
||||
|
||||
# Bundle edge Rails instead: gem 'rails', github: 'rails/rails', branch: 'main' |
||||
gem "rails", "~> 6.1.4" |
||||
# Use postgresql as the database for Active Record |
||||
gem "pg", "~> 1.1" |
||||
# Use Puma as the app server |
||||
gem "puma", "~> 5.0" |
||||
# Transpile app-like JavaScript. Read more: https://github.com/rails/webpacker |
||||
gem "webpacker", "~> 5.0" |
||||
# Build JSON APIs with ease. Read more: https://github.com/rails/jbuilder |
||||
gem "jbuilder", "~> 2.7" |
||||
# Reduces boot times through caching; required in config/boot.rb |
||||
gem "bootsnap", ">= 1.4.4", require: false |
||||
# Gov.UK frontend components |
||||
gem "govuk-components" |
||||
gem "govuk_design_system_formbuilder" |
||||
|
||||
group :development, :test do |
||||
# Call 'byebug' anywhere in the code to stop execution and get a debugger console |
||||
gem "byebug", platforms: %i[mri mingw x64_mingw] |
||||
gem "capybara" |
||||
gem "pry-byebug" |
||||
gem "dotenv-rails" |
||||
gem "selenium-webdriver" |
||||
%w[rspec-core rspec-expectations rspec-mocks rspec-rails rspec-support].each do |lib| |
||||
gem lib, git: "https://github.com/rspec/#{lib}.git", branch: "main" |
||||
end |
||||
end |
||||
|
||||
group :development do |
||||
# Access an interactive console on exception pages or by calling 'console' anywhere in the code. |
||||
gem "web-console", ">= 4.1.0" |
||||
# Display performance information such as SQL time and flame graphs for each request in your browser. |
||||
# Can be configured to work on production as well see: https://github.com/MiniProfiler/rack-mini-profiler/blob/master/README.md |
||||
gem "listen", "~> 3.3" |
||||
gem "rack-mini-profiler", "~> 2.0" |
||||
gem "rubocop-govuk" |
||||
gem "rubocop-performance", require: false |
||||
gem "rubocop-rails" |
||||
gem "scss_lint-govuk" |
||||
gem "overcommit", ">= 0.37.0", require: false |
||||
end |
||||
|
||||
# Windows does not include zoneinfo files, so bundle the tzinfo-data gem |
||||
gem "tzinfo-data", platforms: %i[mingw mswin x64_mingw jruby] |
@ -0,0 +1,342 @@
|
||||
GIT |
||||
remote: https://github.com/rspec/rspec-core.git |
||||
revision: beca9ba93cb71db91e2f37c4cc1bdbacdecd1025 |
||||
branch: main |
||||
specs: |
||||
rspec-core (3.11.0.pre) |
||||
rspec-support (= 3.11.0.pre) |
||||
|
||||
GIT |
||||
remote: https://github.com/rspec/rspec-expectations.git |
||||
revision: dba67987c63f551d1bf0f7877f069fa8b72d0461 |
||||
branch: main |
||||
specs: |
||||
rspec-expectations (3.11.0.pre) |
||||
diff-lcs (>= 1.2.0, < 2.0) |
||||
rspec-support (= 3.11.0.pre) |
||||
|
||||
GIT |
||||
remote: https://github.com/rspec/rspec-mocks.git |
||||
revision: 17cf86ab61544b93232c4e9ca9784ab212dccbf6 |
||||
branch: main |
||||
specs: |
||||
rspec-mocks (3.11.0.pre) |
||||
diff-lcs (>= 1.2.0, < 2.0) |
||||
rspec-support (= 3.11.0.pre) |
||||
|
||||
GIT |
||||
remote: https://github.com/rspec/rspec-rails.git |
||||
revision: e68175d1d6f3e7a70afca7a76a133039e3efd1ec |
||||
branch: main |
||||
specs: |
||||
rspec-rails (5.1.0.pre) |
||||
actionpack (>= 5.2) |
||||
activesupport (>= 5.2) |
||||
railties (>= 5.2) |
||||
rspec-core (= 3.11.0.pre) |
||||
rspec-expectations (= 3.11.0.pre) |
||||
rspec-mocks (= 3.11.0.pre) |
||||
rspec-support (= 3.11.0.pre) |
||||
|
||||
GIT |
||||
remote: https://github.com/rspec/rspec-support.git |
||||
revision: 28526172c42302858c18681d7d7580490d885b4d |
||||
branch: main |
||||
specs: |
||||
rspec-support (3.11.0.pre) |
||||
|
||||
GEM |
||||
remote: https://rubygems.org/ |
||||
specs: |
||||
actioncable (6.1.4) |
||||
actionpack (= 6.1.4) |
||||
activesupport (= 6.1.4) |
||||
nio4r (~> 2.0) |
||||
websocket-driver (>= 0.6.1) |
||||
actionmailbox (6.1.4) |
||||
actionpack (= 6.1.4) |
||||
activejob (= 6.1.4) |
||||
activerecord (= 6.1.4) |
||||
activestorage (= 6.1.4) |
||||
activesupport (= 6.1.4) |
||||
mail (>= 2.7.1) |
||||
actionmailer (6.1.4) |
||||
actionpack (= 6.1.4) |
||||
actionview (= 6.1.4) |
||||
activejob (= 6.1.4) |
||||
activesupport (= 6.1.4) |
||||
mail (~> 2.5, >= 2.5.4) |
||||
rails-dom-testing (~> 2.0) |
||||
actionpack (6.1.4) |
||||
actionview (= 6.1.4) |
||||
activesupport (= 6.1.4) |
||||
rack (~> 2.0, >= 2.0.9) |
||||
rack-test (>= 0.6.3) |
||||
rails-dom-testing (~> 2.0) |
||||
rails-html-sanitizer (~> 1.0, >= 1.2.0) |
||||
actiontext (6.1.4) |
||||
actionpack (= 6.1.4) |
||||
activerecord (= 6.1.4) |
||||
activestorage (= 6.1.4) |
||||
activesupport (= 6.1.4) |
||||
nokogiri (>= 1.8.5) |
||||
actionview (6.1.4) |
||||
activesupport (= 6.1.4) |
||||
builder (~> 3.1) |
||||
erubi (~> 1.4) |
||||
rails-dom-testing (~> 2.0) |
||||
rails-html-sanitizer (~> 1.1, >= 1.2.0) |
||||
activejob (6.1.4) |
||||
activesupport (= 6.1.4) |
||||
globalid (>= 0.3.6) |
||||
activemodel (6.1.4) |
||||
activesupport (= 6.1.4) |
||||
activerecord (6.1.4) |
||||
activemodel (= 6.1.4) |
||||
activesupport (= 6.1.4) |
||||
activestorage (6.1.4) |
||||
actionpack (= 6.1.4) |
||||
activejob (= 6.1.4) |
||||
activerecord (= 6.1.4) |
||||
activesupport (= 6.1.4) |
||||
marcel (~> 1.0.0) |
||||
mini_mime (>= 1.1.0) |
||||
activesupport (6.1.4) |
||||
concurrent-ruby (~> 1.0, >= 1.0.2) |
||||
i18n (>= 1.6, < 2) |
||||
minitest (>= 5.1) |
||||
tzinfo (~> 2.0) |
||||
zeitwerk (~> 2.3) |
||||
addressable (2.8.0) |
||||
public_suffix (>= 2.0.2, < 5.0) |
||||
ast (2.4.2) |
||||
bindex (0.8.1) |
||||
bootsnap (1.7.5) |
||||
msgpack (~> 1.0) |
||||
builder (3.2.4) |
||||
byebug (11.1.3) |
||||
capybara (3.35.3) |
||||
addressable |
||||
mini_mime (>= 0.1.3) |
||||
nokogiri (~> 1.8) |
||||
rack (>= 1.6.0) |
||||
rack-test (>= 0.6.3) |
||||
regexp_parser (>= 1.5, < 3.0) |
||||
xpath (~> 3.2) |
||||
childprocess (3.0.0) |
||||
coderay (1.1.3) |
||||
concurrent-ruby (1.1.9) |
||||
crass (1.0.6) |
||||
deep_merge (1.2.1) |
||||
diff-lcs (1.4.4) |
||||
dotenv (2.7.6) |
||||
dotenv-rails (2.7.6) |
||||
dotenv (= 2.7.6) |
||||
railties (>= 3.2) |
||||
erubi (1.10.0) |
||||
ffi (1.15.3) |
||||
globalid (0.4.2) |
||||
activesupport (>= 4.2.0) |
||||
govuk-components (1.2.0) |
||||
activemodel (>= 6.0) |
||||
railties (>= 6.0) |
||||
view_component (~> 2.20) |
||||
govuk_design_system_formbuilder (2.7.2) |
||||
actionview (>= 6.0) |
||||
activemodel (>= 6.0) |
||||
activesupport (>= 6.0) |
||||
deep_merge (~> 1.2.1) |
||||
i18n (1.8.10) |
||||
concurrent-ruby (~> 1.0) |
||||
iniparse (1.5.0) |
||||
jbuilder (2.11.2) |
||||
activesupport (>= 5.0.0) |
||||
listen (3.5.1) |
||||
rb-fsevent (~> 0.10, >= 0.10.3) |
||||
rb-inotify (~> 0.9, >= 0.9.10) |
||||
loofah (2.10.0) |
||||
crass (~> 1.0.2) |
||||
nokogiri (>= 1.5.9) |
||||
mail (2.7.1) |
||||
mini_mime (>= 0.1.1) |
||||
marcel (1.0.1) |
||||
method_source (1.0.0) |
||||
mini_mime (1.1.0) |
||||
minitest (5.14.4) |
||||
msgpack (1.4.2) |
||||
nio4r (2.5.7) |
||||
nokogiri (1.11.7-x86_64-darwin) |
||||
racc (~> 1.4) |
||||
nokogiri (1.11.7-x86_64-linux) |
||||
racc (~> 1.4) |
||||
overcommit (0.58.0) |
||||
childprocess (>= 0.6.3, < 5) |
||||
iniparse (~> 1.4) |
||||
rexml (~> 3.2) |
||||
parallel (1.20.1) |
||||
parser (3.0.2.0) |
||||
ast (~> 2.4.1) |
||||
pg (1.2.3) |
||||
pry (0.13.1) |
||||
coderay (~> 1.1) |
||||
method_source (~> 1.0) |
||||
pry-byebug (3.9.0) |
||||
byebug (~> 11.0) |
||||
pry (~> 0.13.0) |
||||
public_suffix (4.0.6) |
||||
puma (5.3.2) |
||||
nio4r (~> 2.0) |
||||
racc (1.5.2) |
||||
rack (2.2.3) |
||||
rack-mini-profiler (2.3.2) |
||||
rack (>= 1.2.0) |
||||
rack-proxy (0.7.0) |
||||
rack |
||||
rack-test (1.1.0) |
||||
rack (>= 1.0, < 3) |
||||
rails (6.1.4) |
||||
actioncable (= 6.1.4) |
||||
actionmailbox (= 6.1.4) |
||||
actionmailer (= 6.1.4) |
||||
actionpack (= 6.1.4) |
||||
actiontext (= 6.1.4) |
||||
actionview (= 6.1.4) |
||||
activejob (= 6.1.4) |
||||
activemodel (= 6.1.4) |
||||
activerecord (= 6.1.4) |
||||
activestorage (= 6.1.4) |
||||
activesupport (= 6.1.4) |
||||
bundler (>= 1.15.0) |
||||
railties (= 6.1.4) |
||||
sprockets-rails (>= 2.0.0) |
||||
rails-dom-testing (2.0.3) |
||||
activesupport (>= 4.2.0) |
||||
nokogiri (>= 1.6) |
||||
rails-html-sanitizer (1.3.0) |
||||
loofah (~> 2.3) |
||||
railties (6.1.4) |
||||
actionpack (= 6.1.4) |
||||
activesupport (= 6.1.4) |
||||
method_source |
||||
rake (>= 0.13) |
||||
thor (~> 1.0) |
||||
rainbow (3.0.0) |
||||
rake (13.0.6) |
||||
rb-fsevent (0.11.0) |
||||
rb-inotify (0.10.1) |
||||
ffi (~> 1.0) |
||||
regexp_parser (2.1.1) |
||||
rexml (3.2.5) |
||||
rubocop (1.15.0) |
||||
parallel (~> 1.10) |
||||
parser (>= 3.0.0.0) |
||||
rainbow (>= 2.2.2, < 4.0) |
||||
regexp_parser (>= 1.8, < 3.0) |
||||
rexml |
||||
rubocop-ast (>= 1.5.0, < 2.0) |
||||
ruby-progressbar (~> 1.7) |
||||
unicode-display_width (>= 1.4.0, < 3.0) |
||||
rubocop-ast (1.6.0) |
||||
parser (>= 3.0.1.1) |
||||
rubocop-govuk (4.0.0) |
||||
rubocop (~> 1.15.0) |
||||
rubocop-ast (~> 1.6.0) |
||||
rubocop-rails (~> 2.10.0) |
||||
rubocop-rake (= 0.5.1) |
||||
rubocop-rspec (~> 2.3.0) |
||||
rubocop-performance (1.11.4) |
||||
rubocop (>= 1.7.0, < 2.0) |
||||
rubocop-ast (>= 0.4.0) |
||||
rubocop-rails (2.10.1) |
||||
activesupport (>= 4.2.0) |
||||
rack (>= 1.1) |
||||
rubocop (>= 1.7.0, < 2.0) |
||||
rubocop-rake (0.5.1) |
||||
rubocop |
||||
rubocop-rspec (2.3.0) |
||||
rubocop (~> 1.0) |
||||
rubocop-ast (>= 1.1.0) |
||||
ruby-progressbar (1.11.0) |
||||
rubyzip (2.3.2) |
||||
sass (3.7.4) |
||||
sass-listen (~> 4.0.0) |
||||
sass-listen (4.0.0) |
||||
rb-fsevent (~> 0.9, >= 0.9.4) |
||||
rb-inotify (~> 0.9, >= 0.9.7) |
||||
scss_lint (0.59.0) |
||||
sass (~> 3.5, >= 3.5.5) |
||||
scss_lint-govuk (0.2.0) |
||||
scss_lint |
||||
selenium-webdriver (3.142.7) |
||||
childprocess (>= 0.5, < 4.0) |
||||
rubyzip (>= 1.2.2) |
||||
semantic_range (3.0.0) |
||||
sprockets (4.0.2) |
||||
concurrent-ruby (~> 1.0) |
||||
rack (> 1, < 3) |
||||
sprockets-rails (3.2.2) |
||||
actionpack (>= 4.0) |
||||
activesupport (>= 4.0) |
||||
sprockets (>= 3.0.0) |
||||
thor (1.1.0) |
||||
tzinfo (2.0.4) |
||||
concurrent-ruby (~> 1.0) |
||||
unicode-display_width (2.0.0) |
||||
view_component (2.35.0) |
||||
activesupport (>= 5.0.0, < 8.0) |
||||
method_source (~> 1.0) |
||||
web-console (4.1.0) |
||||
actionview (>= 6.0.0) |
||||
activemodel (>= 6.0.0) |
||||
bindex (>= 0.4.0) |
||||
railties (>= 6.0.0) |
||||
webpacker (5.4.0) |
||||
activesupport (>= 5.2) |
||||
rack-proxy (>= 0.6.1) |
||||
railties (>= 5.2) |
||||
semantic_range (>= 2.3.0) |
||||
websocket-driver (0.7.5) |
||||
websocket-extensions (>= 0.1.0) |
||||
websocket-extensions (0.1.5) |
||||
xpath (3.2.0) |
||||
nokogiri (~> 1.8) |
||||
zeitwerk (2.4.2) |
||||
|
||||
PLATFORMS |
||||
x86_64-darwin-19 |
||||
x86_64-linux |
||||
|
||||
DEPENDENCIES |
||||
bootsnap (>= 1.4.4) |
||||
byebug |
||||
capybara |
||||
dotenv-rails |
||||
govuk-components |
||||
govuk_design_system_formbuilder |
||||
jbuilder (~> 2.7) |
||||
listen (~> 3.3) |
||||
overcommit (>= 0.37.0) |
||||
pg (~> 1.1) |
||||
pry-byebug |
||||
puma (~> 5.0) |
||||
rack-mini-profiler (~> 2.0) |
||||
rails (~> 6.1.4) |
||||
rspec-core! |
||||
rspec-expectations! |
||||
rspec-mocks! |
||||
rspec-rails! |
||||
rspec-support! |
||||
rubocop-govuk |
||||
rubocop-performance |
||||
rubocop-rails |
||||
scss_lint-govuk |
||||
selenium-webdriver |
||||
tzinfo-data |
||||
web-console (>= 4.1.0) |
||||
webpacker (~> 5.0) |
||||
|
||||
RUBY VERSION |
||||
ruby 3.0.0p0 |
||||
|
||||
BUNDLED WITH |
||||
2.2.3 |
@ -0,0 +1,33 @@
|
||||
# Data Collection App |
||||
This is the codebase for the Ruby/Rails app that will handle the submission of Lettings and Sales of Social Housing in England data. |
||||
|
||||
## Required Setup |
||||
|
||||
Pre-requisites |
||||
|
||||
- Ruby |
||||
- Rails |
||||
- Postgres |
||||
|
||||
|
||||
### Setup Quickstart |
||||
|
||||
From the data-collector directory |
||||
|
||||
``` |
||||
rake db:create |
||||
rails s |
||||
``` |
||||
This starts the rails server on localhost:3000 |
||||
|
||||
or using Docker |
||||
|
||||
``` |
||||
docker-compose build |
||||
docker-compose run --rm app rails db:create |
||||
docker-compose up |
||||
``` |
||||
|
||||
This exposes the rails server on localhost:8080. |
||||
|
||||
Note docker-compose runs the production docker image (RAILS_ENV=production) as the Dockerfile doesn't include development gems to keep the image size down. |
@ -0,0 +1,6 @@
|
||||
# Add your own tasks in files placed in lib/tasks ending in .rake, |
||||
# for example lib/tasks/capistrano.rake, and they will automatically be available to Rake. |
||||
|
||||
require_relative "config/application" |
||||
|
||||
Rails.application.load_tasks |
@ -0,0 +1,2 @@
|
||||
//= link_tree ../images
|
||||
//= link_directory ../stylesheets .css
|
@ -0,0 +1,15 @@
|
||||
/* |
||||
* This is a manifest file that'll be compiled into application.css, which will include all the files |
||||
* listed below. |
||||
* |
||||
* Any CSS and SCSS file within this directory, lib/assets/stylesheets, or any plugin's |
||||
* vendor/assets/stylesheets directory can be referenced here using a relative path. |
||||
* |
||||
* You're free to add application-wide styles to this file and they'll appear at the bottom of the |
||||
* compiled file so the styles you add here take precedence over styles defined in any other CSS/SCSS |
||||
* files in this directory. Styles in this file should be added after the last require_* statement. |
||||
* It is generally better to create a new file per style scope. |
||||
* |
||||
*= require_tree . |
||||
*= require_self |
||||
*/ |
@ -0,0 +1,4 @@
|
||||
module ApplicationCable |
||||
class Channel < ActionCable::Channel::Base |
||||
end |
||||
end |
@ -0,0 +1,4 @@
|
||||
module ApplicationCable |
||||
class Connection < ActionCable::Connection::Base |
||||
end |
||||
end |
@ -0,0 +1,3 @@
|
||||
class AboutController < ApplicationController |
||||
def index; end |
||||
end |
@ -0,0 +1,2 @@
|
||||
class ApplicationController < ActionController::Base |
||||
end |
@ -0,0 +1,3 @@
|
||||
class FormController < ApplicationController |
||||
def index; end |
||||
end |
@ -0,0 +1,3 @@
|
||||
class TestController < ApplicationController |
||||
def index; end |
||||
end |
@ -0,0 +1,6 @@
|
||||
// Action Cable provides the framework to deal with WebSockets in Rails.
|
||||
// You can generate new channels where WebSocket features live using the `bin/rails generate channel` command.
|
||||
|
||||
import { createConsumer } from "@rails/actioncable" |
||||
|
||||
export default createConsumer() |
@ -0,0 +1,5 @@
|
||||
// Load all the channels within this directory and all subdirectories.
|
||||
// Channel files must be named *_channel.js.
|
||||
|
||||
const channels = require.context('.', true, /_channel\.js$/) |
||||
channels.keys().forEach(channels) |
@ -0,0 +1,16 @@
|
||||
// This file is automatically compiled by Webpack, along with any other files
|
||||
// present in this directory. You're encouraged to place your actual application logic in
|
||||
// a relevant structure within app/javascript and only use these pack files to reference
|
||||
// that code so it'll be compiled.
|
||||
require.context('govuk-frontend/govuk/assets') |
||||
|
||||
import '../styles/application.scss' |
||||
import Rails from "@rails/ujs" |
||||
import * as ActiveStorage from "@rails/activestorage" |
||||
import "channels" |
||||
import { initAll } from 'govuk-frontend' |
||||
|
||||
|
||||
Rails.start() |
||||
ActiveStorage.start() |
||||
initAll() |
@ -0,0 +1,12 @@
|
||||
@function frontend-font-url($filename) { |
||||
@return url("~assets/fonts/" + $filename); |
||||
} |
||||
|
||||
@function frontend-image-url($filename) { |
||||
@return url("~assets/images/" + $filename); |
||||
} |
||||
|
||||
$govuk-font-url-function: frontend-font-url; |
||||
$govuk-image-url-function: frontend-image-url; |
||||
|
||||
@import "~govuk-frontend/govuk/all"; |
@ -0,0 +1,7 @@
|
||||
class ApplicationJob < ActiveJob::Base |
||||
# Automatically retry jobs that encountered a deadlock |
||||
# retry_on ActiveRecord::Deadlocked |
||||
|
||||
# Most jobs are safe to ignore if the underlying records are no longer available |
||||
# discard_on ActiveJob::DeserializationError |
||||
end |
@ -0,0 +1,4 @@
|
||||
class ApplicationMailer < ActionMailer::Base |
||||
default from: "from@example.com" |
||||
layout "mailer" |
||||
end |
@ -0,0 +1,3 @@
|
||||
class ApplicationRecord < ActiveRecord::Base |
||||
self.abstract_class = true |
||||
end |
@ -0,0 +1,4 @@
|
||||
<%= form_with url:'/test', builder: GOVUKDesignSystemFormBuilder::FormBuilder do |f| %> |
||||
<%= f.govuk_number_field :age, label: { text: "Age" } %> |
||||
<%= f.govuk_submit %> |
||||
<% end %> |
@ -0,0 +1,105 @@
|
||||
<!DOCTYPE html> |
||||
<html lang="en" class="govuk-template "> |
||||
<head> |
||||
<title>MHCLG Data-Collector</title> |
||||
<%= csrf_meta_tags %> |
||||
<%= csp_meta_tag %> |
||||
<%= tag :meta, name: 'viewport', content: 'width=device-width, initial-scale=1' %> |
||||
<%= tag :meta, property: 'og:image', content: asset_pack_path('media/images/govuk-opengraph-image.png') %> |
||||
<%= tag :meta, name: 'theme-color', content: '#0b0c0c' %> |
||||
<%= favicon_link_tag asset_pack_path('media/images/favicon.ico') %> |
||||
<%= favicon_link_tag asset_pack_path('media/images/govuk-mask-icon.svg'), rel: 'mask-icon', type: 'image/svg', color: "#0b0c0c" %> |
||||
<%= favicon_link_tag asset_pack_path('media/images/govuk-apple-touch-icon.png'), rel: 'apple-touch-icon', type: 'image/png' %> |
||||
<%= favicon_link_tag asset_pack_path('media/images/govuk-apple-touch-icon-152x152.png'), rel: 'apple-touch-icon', type: 'image/png', size: '152x152' %> |
||||
<%= favicon_link_tag asset_pack_path('media/images/govuk-apple-touch-icon-167x167.png'), rel: 'apple-touch-icon', type: 'image/png', size: '167x167' %> |
||||
<%= favicon_link_tag asset_pack_path('media/images/govuk-apple-touch-icon-180x180.png'), rel: 'apple-touch-icon', type: 'image/png', size: '180x180' %> |
||||
<%= stylesheet_pack_tag 'application', media: 'all' %> |
||||
<%= javascript_pack_tag 'application', defer: true %> |
||||
|
||||
|
||||
<% if Rails.env.development? %> |
||||
<script> |
||||
console.log(<%= session.to_json.html_safe %>) |
||||
</script> |
||||
<% end %> |
||||
</head> |
||||
|
||||
<body class="govuk-template__body "> |
||||
|
||||
<script> |
||||
document.body.className = ((document.body.className) ? document.body.className + ' js-enabled' : 'js-enabled'); |
||||
</script> |
||||
|
||||
<a href="#main-content" class="govuk-skip-link">Skip to main content</a> |
||||
|
||||
<header class="govuk-header" role="banner" data-module="govuk-header"> |
||||
<div class="govuk-header__container govuk-width-container"> |
||||
<div class="govuk-header__logo"> |
||||
<%= link_to "/", class: "govuk-header__link govuk-header__link--homepage" do %> |
||||
<span class="govuk-header__logotype"> |
||||
<svg role="presentation" focusable="false" class="govuk-header__logotype-crown" xmlns="http://www.w3.org/2000/svg" viewbox="0 0 132 97" height="32" width="36"> |
||||
<path fill="currentColor" fill-rule="evenodd" d="M25 30.2c3.5 1.5 7.7-.2 9.1-3.7 1.5-3.6-.2-7.8-3.9-9.2-3.6-1.4-7.6.3-9.1 3.9-1.4 3.5.3 7.5 3.9 9zM9 39.5c3.6 1.5 7.8-.2 9.2-3.7 1.5-3.6-.2-7.8-3.9-9.1-3.6-1.5-7.6.2-9.1 3.8-1.4 3.5.3 7.5 3.8 9zM4.4 57.2c3.5 1.5 7.7-.2 9.1-3.8 1.5-3.6-.2-7.7-3.9-9.1-3.5-1.5-7.6.3-9.1 3.8-1.4 3.5.3 7.6 3.9 9.1zm38.3-21.4c3.5 1.5 7.7-.2 9.1-3.8 1.5-3.6-.2-7.7-3.9-9.1-3.6-1.5-7.6.3-9.1 3.8-1.3 3.6.4 7.7 3.9 9.1zm64.4-5.6c-3.6 1.5-7.8-.2-9.1-3.7-1.5-3.6.2-7.8 3.8-9.2 3.6-1.4 7.7.3 9.2 3.9 1.3 3.5-.4 7.5-3.9 9zm15.9 9.3c-3.6 1.5-7.7-.2-9.1-3.7-1.5-3.6.2-7.8 3.7-9.1 3.6-1.5 7.7.2 9.2 3.8 1.5 3.5-.3 7.5-3.8 9zm4.7 17.7c-3.6 1.5-7.8-.2-9.2-3.8-1.5-3.6.2-7.7 3.9-9.1 3.6-1.5 7.7.3 9.2 3.8 1.3 3.5-.4 7.6-3.9 9.1zM89.3 35.8c-3.6 1.5-7.8-.2-9.2-3.8-1.4-3.6.2-7.7 3.9-9.1 3.6-1.5 7.7.3 9.2 3.8 1.4 3.6-.3 7.7-3.9 9.1zM69.7 17.7l8.9 4.7V9.3l-8.9 2.8c-.2-.3-.5-.6-.9-.9L72.4 0H59.6l3.5 11.2c-.3.3-.6.5-.9.9l-8.8-2.8v13.1l8.8-4.7c.3.3.6.7.9.9l-5 15.4v.1c-.2.8-.4 1.6-.4 2.4 0 4.1 3.1 7.5 7 8.1h.2c.3 0 .7.1 1 .1.4 0 .7 0 1-.1h.2c4-.6 7.1-4.1 7.1-8.1 0-.8-.1-1.7-.4-2.4V34l-5.1-15.4c.4-.2.7-.6 1-.9zM66 92.8c16.9 0 32.8 1.1 47.1 3.2 4-16.9 8.9-26.7 14-33.5l-9.6-3.4c1 4.9 1.1 7.2 0 10.2-1.5-1.4-3-4.3-4.2-8.7L108.6 76c2.8-2 5-3.2 7.5-3.3-4.4 9.4-10 11.9-13.6 11.2-4.3-.8-6.3-4.6-5.6-7.9 1-4.7 5.7-5.9 8-.5 4.3-8.7-3-11.4-7.6-8.8 7.1-7.2 7.9-13.5 2.1-21.1-8 6.1-8.1 12.3-4.5 20.8-4.7-5.4-12.1-2.5-9.5 6.2 3.4-5.2 7.9-2 7.2 3.1-.6 4.3-6.4 7.8-13.5 7.2-10.3-.9-10.9-8-11.2-13.8 2.5-.5 7.1 1.8 11 7.3L80.2 60c-4.1 4.4-8 5.3-12.3 5.4 1.4-4.4 8-11.6 8-11.6H55.5s6.4 7.2 7.9 11.6c-4.2-.1-8-1-12.3-5.4l1.4 16.4c3.9-5.5 8.5-7.7 10.9-7.3-.3 5.8-.9 12.8-11.1 13.8-7.2.6-12.9-2.9-13.5-7.2-.7-5 3.8-8.3 7.1-3.1 2.7-8.7-4.6-11.6-9.4-6.2 3.7-8.5 3.6-14.7-4.6-20.8-5.8 7.6-5 13.9 2.2 21.1-4.7-2.6-11.9.1-7.7 8.8 2.3-5.5 7.1-4.2 8.1.5.7 3.3-1.3 7.1-5.7 7.9-3.5.7-9-1.8-13.5-11.2 2.5.1 4.7 1.3 7.5 3.3l-4.7-15.4c-1.2 4.4-2.7 7.2-4.3 8.7-1.1-3-.9-5.3 0-10.2l-9.5 3.4c5 6.9 9.9 16.7 14 33.5 14.8-2.1 30.8-3.2 47.7-3.2z"></path> |
||||
<image src="<%= asset_pack_path('media/images/govuk-logotype-crown.png') %>" class="govuk-header__logotype-crown-fallback-image"></image> |
||||
</svg> |
||||
<span class="govuk-header__logotype-text"> |
||||
GOV.UK |
||||
</span> |
||||
</span> |
||||
<% end %> |
||||
</div> |
||||
|
||||
<div class="govuk-header__content"> |
||||
<%= link_to "Share Lettings and Sales for Social Housing in England Data with MHCLG", "/", class: "govuk-header__link govuk-header__link--service-name" %> |
||||
</div> |
||||
</div> |
||||
</header> |
||||
|
||||
<aside class="govuk-width-container"> |
||||
<%= render GovukComponent::PhaseBanner.new( |
||||
phase_tag: { text: 'Beta' }, |
||||
text: "This is a new service – #{govuk_mail_to("test@mhclg.gov.uk", "give feedback or report a problem", subject: "Feedback about Lettings and Sales of Social Housing in England Data Collection")}".html_safe |
||||
) %> |
||||
</aside> |
||||
|
||||
<div class="govuk-width-container"> |
||||
<div role="navigation"> |
||||
<%= content_for(:before_content) %> |
||||
</div> |
||||
|
||||
<main class="govuk-main-wrapper " id="main-content" role="main"> |
||||
<%= yield %> |
||||
</main> |
||||
</div> |
||||
|
||||
<footer class="govuk-footer"> |
||||
<div class="govuk-width-container "> |
||||
<div class="govuk-footer__meta"> |
||||
<div class="govuk-footer__meta-item govuk-footer__meta-item--grow"> |
||||
<h2 class="govuk-visually-hidden">Support links</h2> |
||||
|
||||
<div class="govuk-footer__meta-custom"> |
||||
<h2 class="govuk-heading-m">Support and guidance</h2> |
||||
|
||||
<p class="govuk-body-s"> |
||||
If you have a question, or you've had a problem using this service, please contact us at <%= mail_to "test@mhclg.gov.uk", "test@mhclg.gov.uk", class: "govuk-footer__link" %> |
||||
</p> |
||||
|
||||
</div> |
||||
|
||||
<svg aria-hidden="true" focusable="false" class="govuk-footer__licence-logo" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 483.2 195.7" height="17" width="41"> |
||||
<path fill="currentColor" d="M421.5 142.8V.1l-50.7 32.3v161.1h112.4v-50.7zm-122.3-9.6A47.12 47.12 0 0 1 221 97.8c0-26 21.1-47.1 47.1-47.1 16.7 0 31.4 8.7 39.7 21.8l42.7-27.2A97.63 97.63 0 0 0 268.1 0c-36.5 0-68.3 20.1-85.1 49.7A98 98 0 0 0 97.8 0C43.9 0 0 43.9 0 97.8s43.9 97.8 97.8 97.8c36.5 0 68.3-20.1 85.1-49.7a97.76 97.76 0 0 0 149.6 25.4l19.4 22.2h3v-87.8h-80l24.3 27.5zM97.8 145c-26 0-47.1-21.1-47.1-47.1s21.1-47.1 47.1-47.1 47.2 21 47.2 47S123.8 145 97.8 145" /> |
||||
</svg> |
||||
|
||||
<span class="govuk-footer__licence-description"> |
||||
All content is available under the |
||||
<a class="govuk-footer__link" href="https://www.nationalarchives.gov.uk/doc/open-government-licence/version/3/" rel="license">Open Government Licence v3.0</a>, except where otherwise stated |
||||
</span> |
||||
</div> |
||||
<div class="govuk-footer__meta-item"> |
||||
<a class="govuk-footer__link govuk-footer__copyright-logo" href="https://www.nationalarchives.gov.uk/information-management/re-using-public-sector-information/uk-government-licensing-framework/crown-copyright/">© Crown copyright</a> |
||||
</div> |
||||
</div> |
||||
</div> |
||||
</footer> |
||||
</body> |
||||
</html> |
@ -0,0 +1,13 @@
|
||||
<!DOCTYPE html> |
||||
<html> |
||||
<head> |
||||
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> |
||||
<style> |
||||
/* Email styles need to be inline */ |
||||
</style> |
||||
</head> |
||||
|
||||
<body> |
||||
<%= yield %> |
||||
</body> |
||||
</html> |
@ -0,0 +1,31 @@
|
||||
<%= render GovukComponent::Accordion.new(id: 'abc123') do |component| |
||||
component.slot(:section, |
||||
title: 'Home electronics', |
||||
summary: 'Entertainment, communication and recreation', |
||||
expanded: true) do |
||||
tag.p(class: 'govuk-body') do |
||||
"Lorem ipsum dolor sit amet, consectetur adipiscing elit." |
||||
end |
||||
end |
||||
|
||||
component.slot(:section, |
||||
title: 'Appliances', summary: 'Laundry, cookers and vacuum cleaners') do |
||||
tag.p(class: 'govuk-body') do |
||||
"Ut et elementum tortor. Donec a tellus sed sem euismod congue" |
||||
end |
||||
end |
||||
|
||||
component.slot(:section, title: 'Toys') do |
||||
safe_join([ |
||||
tag.p(class: 'govuk-body') do |
||||
"In et nunc vitae tortor sollicitudin ultrices. Vivamus a purus justo." |
||||
end, |
||||
|
||||
tag.p(class: 'govuk-body') do |
||||
"Duis a turpis non nunc pulvinar venenatis quis congue mauris" |
||||
end |
||||
]) |
||||
end |
||||
end %> |
||||
|
||||
<%= link_to('About', about_path) %> |
@ -0,0 +1,70 @@
|
||||
module.exports = function(api) { |
||||
var validEnv = ['development', 'test', 'production'] |
||||
var currentEnv = api.env() |
||||
var isDevelopmentEnv = api.env('development') |
||||
var isProductionEnv = api.env('production') |
||||
var isTestEnv = api.env('test') |
||||
|
||||
if (!validEnv.includes(currentEnv)) { |
||||
throw new Error( |
||||
'Please specify a valid `NODE_ENV` or ' + |
||||
'`BABEL_ENV` environment variables. Valid values are "development", ' + |
||||
'"test", and "production". Instead, received: ' + |
||||
JSON.stringify(currentEnv) + |
||||
'.' |
||||
) |
||||
} |
||||
|
||||
return { |
||||
presets: [ |
||||
isTestEnv && [ |
||||
'@babel/preset-env', |
||||
{ |
||||
targets: { |
||||
node: 'current' |
||||
} |
||||
} |
||||
], |
||||
(isProductionEnv || isDevelopmentEnv) && [ |
||||
'@babel/preset-env', |
||||
{ |
||||
forceAllTransforms: true, |
||||
useBuiltIns: 'entry', |
||||
corejs: 3, |
||||
modules: false, |
||||
exclude: ['transform-typeof-symbol'] |
||||
} |
||||
] |
||||
].filter(Boolean), |
||||
plugins: [ |
||||
'babel-plugin-macros', |
||||
'@babel/plugin-syntax-dynamic-import', |
||||
isTestEnv && 'babel-plugin-dynamic-import-node', |
||||
'@babel/plugin-transform-destructuring', |
||||
[ |
||||
'@babel/plugin-proposal-class-properties', |
||||
{ |
||||
loose: true |
||||
} |
||||
], |
||||
[ |
||||
'@babel/plugin-proposal-object-rest-spread', |
||||
{ |
||||
useBuiltIns: true |
||||
} |
||||
], |
||||
[ |
||||
'@babel/plugin-transform-runtime', |
||||
{ |
||||
helpers: false |
||||
} |
||||
], |
||||
[ |
||||
'@babel/plugin-transform-regenerator', |
||||
{ |
||||
async: false |
||||
} |
||||
] |
||||
].filter(Boolean) |
||||
} |
||||
} |
@ -0,0 +1,4 @@
|
||||
#!/usr/bin/env ruby |
||||
APP_PATH = File.expand_path('../config/application', __dir__) |
||||
require_relative "../config/boot" |
||||
require "rails/commands" |
@ -0,0 +1,4 @@
|
||||
#!/usr/bin/env ruby |
||||
require_relative "../config/boot" |
||||
require "rake" |
||||
Rake.application.run |
@ -0,0 +1,36 @@
|
||||
#!/usr/bin/env ruby |
||||
require "fileutils" |
||||
|
||||
# path to your application root. |
||||
APP_ROOT = File.expand_path('..', __dir__) |
||||
|
||||
def system!(*args) |
||||
system(*args) || abort("\n== Command #{args} failed ==") |
||||
end |
||||
|
||||
FileUtils.chdir APP_ROOT do |
||||
# This script is a way to set up or update your development environment automatically. |
||||
# This script is idempotent, so that you can run it at any time and get an expectable outcome. |
||||
# Add necessary setup steps to this file. |
||||
|
||||
puts '== Installing dependencies ==' |
||||
system! 'gem install bundler --conservative' |
||||
system('bundle check') || system!('bundle install') |
||||
|
||||
# Install JavaScript dependencies |
||||
system! 'bin/yarn' |
||||
|
||||
# puts "\n== Copying sample files ==" |
||||
# unless File.exist?('config/database.yml') |
||||
# FileUtils.cp 'config/database.yml.sample', 'config/database.yml' |
||||
# end |
||||
|
||||
puts "\n== Preparing database ==" |
||||
system! 'bin/rails db:prepare' |
||||
|
||||
puts "\n== Removing old logs and tempfiles ==" |
||||
system! 'bin/rails log:clear tmp:clear' |
||||
|
||||
puts "\n== Restarting application server ==" |
||||
system! 'bin/rails restart' |
||||
end |
@ -0,0 +1,18 @@
|
||||
#!/usr/bin/env ruby |
||||
|
||||
ENV["RAILS_ENV"] ||= ENV["RACK_ENV"] || "development" |
||||
ENV["NODE_ENV"] ||= "development" |
||||
|
||||
require "pathname" |
||||
ENV["BUNDLE_GEMFILE"] ||= File.expand_path("../../Gemfile", |
||||
Pathname.new(__FILE__).realpath) |
||||
|
||||
require "bundler/setup" |
||||
|
||||
require "webpacker" |
||||
require "webpacker/webpack_runner" |
||||
|
||||
APP_ROOT = File.expand_path("..", __dir__) |
||||
Dir.chdir(APP_ROOT) do |
||||
Webpacker::WebpackRunner.run(ARGV) |
||||
end |
@ -0,0 +1,18 @@
|
||||
#!/usr/bin/env ruby |
||||
|
||||
ENV["RAILS_ENV"] ||= ENV["RACK_ENV"] || "development" |
||||
ENV["NODE_ENV"] ||= "development" |
||||
|
||||
require "pathname" |
||||
ENV["BUNDLE_GEMFILE"] ||= File.expand_path("../../Gemfile", |
||||
Pathname.new(__FILE__).realpath) |
||||
|
||||
require "bundler/setup" |
||||
|
||||
require "webpacker" |
||||
require "webpacker/dev_server_runner" |
||||
|
||||
APP_ROOT = File.expand_path("..", __dir__) |
||||
Dir.chdir(APP_ROOT) do |
||||
Webpacker::DevServerRunner.run(ARGV) |
||||
end |
@ -0,0 +1,17 @@
|
||||
#!/usr/bin/env ruby |
||||
APP_ROOT = File.expand_path('..', __dir__) |
||||
Dir.chdir(APP_ROOT) do |
||||
yarn = ENV["PATH"].split(File::PATH_SEPARATOR). |
||||
select { |dir| File.expand_path(dir) != __dir__ }. |
||||
product(["yarn", "yarn.cmd", "yarn.ps1"]). |
||||
map { |dir, file| File.expand_path(file, dir) }. |
||||
find { |file| File.executable?(file) } |
||||
|
||||
if yarn |
||||
exec yarn, *ARGV |
||||
else |
||||
$stderr.puts "Yarn executable was not detected in the system." |
||||
$stderr.puts "Download Yarn at https://yarnpkg.com/en/docs/install" |
||||
exit 1 |
||||
end |
||||
end |
@ -0,0 +1,6 @@
|
||||
# This file is used by Rack-based servers to start the application. |
||||
|
||||
require_relative "config/environment" |
||||
|
||||
run Rails.application |
||||
Rails.application.load_server |
@ -0,0 +1,38 @@
|
||||
require_relative "boot" |
||||
|
||||
require "rails" |
||||
# Pick the frameworks you want: |
||||
require "active_model/railtie" |
||||
require "active_job/railtie" |
||||
require "active_record/railtie" |
||||
require "active_storage/engine" |
||||
require "action_controller/railtie" |
||||
require "action_mailer/railtie" |
||||
require "action_mailbox/engine" |
||||
require "action_text/engine" |
||||
require "action_view/railtie" |
||||
require "action_cable/engine" |
||||
# require "sprockets/railtie" |
||||
# require "rails/test_unit/railtie" |
||||
|
||||
# Require the gems listed in Gemfile, including any gems |
||||
# you've limited to :test, :development, or :production. |
||||
Bundler.require(*Rails.groups) |
||||
|
||||
module DataCollector |
||||
class Application < Rails::Application |
||||
# Initialize configuration defaults for originally generated Rails version. |
||||
config.load_defaults 6.1 |
||||
|
||||
# Configuration for the application, engines, and railties goes here. |
||||
# |
||||
# These settings can be overridden in specific environments using the files |
||||
# in config/environments, which are processed later. |
||||
# |
||||
# config.time_zone = "Central Time (US & Canada)" |
||||
# config.eager_load_paths << Rails.root.join("extras") |
||||
|
||||
# Don't generate system test files. |
||||
config.generators.system_tests = nil |
||||
end |
||||
end |
@ -0,0 +1,4 @@
|
||||
ENV["BUNDLE_GEMFILE"] ||= File.expand_path("../Gemfile", __dir__) |
||||
|
||||
require "bundler/setup" # Set up gems listed in the Gemfile. |
||||
require "bootsnap/setup" # Speed up boot time by caching expensive operations. |
@ -0,0 +1,10 @@
|
||||
development: |
||||
adapter: async |
||||
|
||||
test: |
||||
adapter: test |
||||
|
||||
production: |
||||
adapter: redis |
||||
url: <%= ENV.fetch("REDIS_URL") { "redis://localhost:6379/1" } %> |
||||
channel_prefix: data_collector_production |
@ -0,0 +1 @@
|
||||
Yx7WqSPL8cL4Hu0yPFBxnHggch9isfjh3yoeSs78giA2C3LF4IWx4T9cMqW7mMbavFho0tH+PcJf6liqmT89cxyp1an6nN3kp6ghoex6WUTp9cHiwPU/Dv3eEF0GvwK0dqJ05pdCLTwxObPdDFXhA3m5PhJ1CVyP72GAadHQukBMJdympTKssHtzxPWrb1dPY0m68xhhDLb2JxHF8Ak3AlAPbRKDeRdaCV/cK1IRerL3pt/Vmq9prxDQ+jo3LEsbS1dHR8wWHRUSb5j1shYteANZ9bROBN6LRkH+quGPcTZfjz9UkutwxN4OhkFgQ1w03MKMqSuOZo4FGuuW3RSMC2HbCCoMNN5HCTJ7opl7TzP0CxZWhhphYaCzoq1eUrnlTQ4p6DKhbegnXjBxWy+rB98+rgDzskCL2a7i--TT5RhCZ+f/HaLit7--MDspf1Efv86as9hig3AU7w== |
@ -0,0 +1,89 @@
|
||||
# PostgreSQL. Versions 9.3 and up are supported. |
||||
# |
||||
# Install the pg driver: |
||||
# gem install pg |
||||
# On macOS with Homebrew: |
||||
# gem install pg -- --with-pg-config=/usr/local/bin/pg_config |
||||
# On macOS with MacPorts: |
||||
# gem install pg -- --with-pg-config=/opt/local/lib/postgresql84/bin/pg_config |
||||
# On Windows: |
||||
# gem install pg |
||||
# Choose the win32 build. |
||||
# Install PostgreSQL and put its /bin directory on your path. |
||||
# |
||||
# Configure Using Gemfile |
||||
# gem 'pg' |
||||
# |
||||
default: &default |
||||
adapter: postgresql |
||||
encoding: unicode |
||||
# For details on connection pooling, see Rails configuration guide |
||||
# https://guides.rubyonrails.org/configuring.html#database-pooling |
||||
pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> |
||||
host: <%= ENV['DB_HOST'] %> |
||||
database: <%= ENV['DB_DATABASE'] %> |
||||
username: <%= ENV['DB_USERNAME'] %> |
||||
password: <%= ENV['DB_PASSWORD'] %> |
||||
port: <%= ENV['POSTGRES_PORT'] || '5432' %> |
||||
|
||||
development: |
||||
<<: *default |
||||
database: data_collector_development |
||||
host: localhost |
||||
|
||||
# The specified database role being used to connect to postgres. |
||||
# To create additional roles in postgres see `$ createuser --help`. |
||||
# When left blank, postgres will use the default role. This is |
||||
# the same name as the operating system user running Rails. |
||||
#username: data_collector |
||||
|
||||
# The password associated with the postgres role (username). |
||||
#password: |
||||
|
||||
# Connect on a TCP socket. Omitted by default since the client uses a |
||||
# domain socket that doesn't need configuration. Windows does not have |
||||
# domain sockets, so uncomment these lines. |
||||
#host: localhost |
||||
|
||||
# The TCP port the server listens on. Defaults to 5432. |
||||
# If your server runs on a different port number, change accordingly. |
||||
#port: 5432 |
||||
|
||||
# Schema search path. The server defaults to $user,public |
||||
#schema_search_path: myapp,sharedapp,public |
||||
|
||||
# Minimum log levels, in increasing order: |
||||
# debug5, debug4, debug3, debug2, debug1, |
||||
# log, notice, warning, error, fatal, and panic |
||||
# Defaults to warning. |
||||
#min_messages: notice |
||||
|
||||
# Warning: The database defined as "test" will be erased and |
||||
# re-generated from your development database when you run "rake". |
||||
# Do not set this db to the same as development or production. |
||||
test: |
||||
<<: *default |
||||
database: data_collector_test |
||||
|
||||
# As with config/credentials.yml, you never want to store sensitive information, |
||||
# like your database password, in your source code. If your source code is |
||||
# ever seen by anyone, they now have access to your database. |
||||
# |
||||
# Instead, provide the password or a full connection URL as an environment |
||||
# variable when you boot the app. For example: |
||||
# |
||||
# DATABASE_URL="postgres://myuser:mypass@localhost/somedatabase" |
||||
# |
||||
# If the connection URL is provided in the special DATABASE_URL environment |
||||
# variable, Rails will automatically merge its configuration values on top of |
||||
# the values provided in this file. Alternatively, you can specify a connection |
||||
# URL environment variable explicitly: |
||||
# |
||||
# production: |
||||
# url: <%= ENV['MY_APP_DATABASE_URL'] %> |
||||
# |
||||
# Read https://guides.rubyonrails.org/configuring.html#configuring-a-database |
||||
# for a full overview on how database connection configuration can be specified. |
||||
# |
||||
production: |
||||
<<: *default |
@ -0,0 +1,5 @@
|
||||
# Load the Rails application. |
||||
require_relative "application" |
||||
|
||||
# Initialize the Rails application. |
||||
Rails.application.initialize! |
@ -0,0 +1,68 @@
|
||||
require "active_support/core_ext/integer/time" |
||||
|
||||
Rails.application.configure do |
||||
# Settings specified here will take precedence over those in config/application.rb. |
||||
|
||||
# In the development environment your application's code is reloaded any time |
||||
# it changes. This slows down response time but is perfect for development |
||||
# since you don't have to restart the web server when you make code changes. |
||||
config.cache_classes = false |
||||
|
||||
# Do not eager load code on boot. |
||||
config.eager_load = false |
||||
|
||||
# Show full error reports. |
||||
config.consider_all_requests_local = true |
||||
|
||||
# Enable/disable caching. By default caching is disabled. |
||||
# Run rails dev:cache to toggle caching. |
||||
if Rails.root.join("tmp/caching-dev.txt").exist? |
||||
config.action_controller.perform_caching = true |
||||
config.action_controller.enable_fragment_cache_logging = true |
||||
|
||||
config.cache_store = :memory_store |
||||
config.public_file_server.headers = { |
||||
"Cache-Control" => "public, max-age=#{2.days.to_i}", |
||||
} |
||||
else |
||||
config.action_controller.perform_caching = false |
||||
|
||||
config.cache_store = :null_store |
||||
end |
||||
|
||||
# Store uploaded files on the local file system (see config/storage.yml for options). |
||||
config.active_storage.service = :local |
||||
|
||||
# Don't care if the mailer can't send. |
||||
config.action_mailer.raise_delivery_errors = false |
||||
|
||||
config.action_mailer.perform_caching = false |
||||
|
||||
# Print deprecation notices to the Rails logger. |
||||
config.active_support.deprecation = :log |
||||
|
||||
# Raise exceptions for disallowed deprecations. |
||||
config.active_support.disallowed_deprecation = :raise |
||||
|
||||
# Tell Active Support which deprecation messages to disallow. |
||||
config.active_support.disallowed_deprecation_warnings = [] |
||||
|
||||
# Raise an error on page load if there are pending migrations. |
||||
config.active_record.migration_error = :page_load |
||||
|
||||
# Highlight code that triggered database queries in logs. |
||||
config.active_record.verbose_query_logs = true |
||||
|
||||
# Raises error for missing translations. |
||||
# config.i18n.raise_on_missing_translations = true |
||||
|
||||
# Annotate rendered view with file names. |
||||
# config.action_view.annotate_rendered_view_with_filenames = true |
||||
|
||||
# Use an evented file watcher to asynchronously detect changes in source code, |
||||
# routes, locales, etc. This feature depends on the listen gem. |
||||
config.file_watcher = ActiveSupport::EventedFileUpdateChecker |
||||
|
||||
# Uncomment if you wish to allow Action Cable access from any origin. |
||||
# config.action_cable.disable_request_forgery_protection = true |
||||
end |
@ -0,0 +1,114 @@
|
||||
require "active_support/core_ext/integer/time" |
||||
|
||||
Rails.application.configure do |
||||
# Settings specified here will take precedence over those in config/application.rb. |
||||
|
||||
# Code is not reloaded between requests. |
||||
config.cache_classes = true |
||||
|
||||
# Eager load code on boot. This eager loads most of Rails and |
||||
# your application in memory, allowing both threaded web servers |
||||
# and those relying on copy on write to perform better. |
||||
# Rake tasks automatically ignore this option for performance. |
||||
config.eager_load = true |
||||
|
||||
# Full error reports are disabled and caching is turned on. |
||||
config.consider_all_requests_local = false |
||||
config.action_controller.perform_caching = true |
||||
|
||||
# Ensures that a master key has been made available in either ENV["RAILS_MASTER_KEY"] |
||||
# or in config/master.key. This key is used to decrypt credentials (and other encrypted files). |
||||
# config.require_master_key = true |
||||
|
||||
# Disable serving static files from the `/public` folder by default since |
||||
# Apache or NGINX already handles this. |
||||
config.public_file_server.enabled = ENV["RAILS_SERVE_STATIC_FILES"].present? |
||||
|
||||
# Enable serving of images, stylesheets, and JavaScripts from an asset server. |
||||
# config.asset_host = 'http://assets.example.com' |
||||
|
||||
# Specifies the header that your server uses for sending files. |
||||
# config.action_dispatch.x_sendfile_header = 'X-Sendfile' # for Apache |
||||
# config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for NGINX |
||||
|
||||
# Store uploaded files on the local file system (see config/storage.yml for options). |
||||
config.active_storage.service = :local |
||||
|
||||
# Mount Action Cable outside main process or domain. |
||||
# config.action_cable.mount_path = nil |
||||
# config.action_cable.url = 'wss://example.com/cable' |
||||
# config.action_cable.allowed_request_origins = [ 'http://example.com', /http:\/\/example.*/ ] |
||||
|
||||
# Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies. |
||||
# config.force_ssl = true |
||||
|
||||
# Include generic and useful information about system operation, but avoid logging too much |
||||
# information to avoid inadvertent exposure of personally identifiable information (PII). |
||||
config.log_level = :info |
||||
|
||||
# Prepend all log lines with the following tags. |
||||
config.log_tags = [:request_id] |
||||
|
||||
# Use a different cache store in production. |
||||
# config.cache_store = :mem_cache_store |
||||
|
||||
# Use a real queuing backend for Active Job (and separate queues per environment). |
||||
# config.active_job.queue_adapter = :resque |
||||
# config.active_job.queue_name_prefix = "data_collector_production" |
||||
|
||||
config.action_mailer.perform_caching = false |
||||
|
||||
# Ignore bad email addresses and do not raise email delivery errors. |
||||
# Set this to true and configure the email server for immediate delivery to raise delivery errors. |
||||
# config.action_mailer.raise_delivery_errors = false |
||||
|
||||
# Enable locale fallbacks for I18n (makes lookups for any locale fall back to |
||||
# the I18n.default_locale when a translation cannot be found). |
||||
config.i18n.fallbacks = true |
||||
|
||||
# Send deprecation notices to registered listeners. |
||||
config.active_support.deprecation = :notify |
||||
|
||||
# Log disallowed deprecations. |
||||
config.active_support.disallowed_deprecation = :log |
||||
|
||||
# Tell Active Support which deprecation messages to disallow. |
||||
config.active_support.disallowed_deprecation_warnings = [] |
||||
|
||||
# Use default logging formatter so that PID and timestamp are not suppressed. |
||||
config.log_formatter = ::Logger::Formatter.new |
||||
|
||||
# Use a different logger for distributed setups. |
||||
# require "syslog/logger" |
||||
# config.logger = ActiveSupport::TaggedLogging.new(Syslog::Logger.new 'app-name') |
||||
|
||||
if ENV["RAILS_LOG_TO_STDOUT"].present? |
||||
logger = ActiveSupport::Logger.new($stdout) |
||||
logger.formatter = config.log_formatter |
||||
config.logger = ActiveSupport::TaggedLogging.new(logger) |
||||
end |
||||
|
||||
# Do not dump schema after migrations. |
||||
config.active_record.dump_schema_after_migration = false |
||||
|
||||
# Inserts middleware to perform automatic connection switching. |
||||
# The `database_selector` hash is used to pass options to the DatabaseSelector |
||||
# middleware. The `delay` is used to determine how long to wait after a write |
||||
# to send a subsequent read to the primary. |
||||
# |
||||
# The `database_resolver` class is used by the middleware to determine which |
||||
# database is appropriate to use based on the time delay. |
||||
# |
||||
# The `database_resolver_context` class is used by the middleware to set |
||||
# timestamps for the last write to the primary. The resolver uses the context |
||||
# class timestamps to determine how long to wait before reading from the |
||||
# replica. |
||||
# |
||||
# By default Rails will store a last write timestamp in the session. The |
||||
# DatabaseSelector middleware is designed as such you can define your own |
||||
# strategy for connection switching and pass that into the middleware through |
||||
# these configuration options. |
||||
# config.active_record.database_selector = { delay: 2.seconds } |
||||
# config.active_record.database_resolver = ActiveRecord::Middleware::DatabaseSelector::Resolver |
||||
# config.active_record.database_resolver_context = ActiveRecord::Middleware::DatabaseSelector::Resolver::Session |
||||
end |
@ -0,0 +1,59 @@
|
||||
require "active_support/core_ext/integer/time" |
||||
|
||||
# The test environment is used exclusively to run your application's |
||||
# test suite. You never need to work with it otherwise. Remember that |
||||
# your test database is "scratch space" for the test suite and is wiped |
||||
# and recreated between test runs. Don't rely on the data there! |
||||
|
||||
Rails.application.configure do |
||||
# Settings specified here will take precedence over those in config/application.rb. |
||||
|
||||
config.cache_classes = true |
||||
|
||||
# Do not eager load code on boot. This avoids loading your whole application |
||||
# just for the purpose of running a single test. If you are using a tool that |
||||
# preloads Rails for running tests, you may have to set it to true. |
||||
config.eager_load = false |
||||
|
||||
# Configure public file server for tests with Cache-Control for performance. |
||||
config.public_file_server.enabled = true |
||||
config.public_file_server.headers = { |
||||
"Cache-Control" => "public, max-age=#{1.hour.to_i}", |
||||
} |
||||
|
||||
# Show full error reports and disable caching. |
||||
config.consider_all_requests_local = true |
||||
config.action_controller.perform_caching = false |
||||
config.cache_store = :null_store |
||||
|
||||
# Raise exceptions instead of rendering exception templates. |
||||
config.action_dispatch.show_exceptions = false |
||||
|
||||
# Disable request forgery protection in test environment. |
||||
config.action_controller.allow_forgery_protection = false |
||||
|
||||
# Store uploaded files on the local file system in a temporary directory. |
||||
config.active_storage.service = :test |
||||
|
||||
config.action_mailer.perform_caching = false |
||||
|
||||
# Tell Action Mailer not to deliver emails to the real world. |
||||
# The :test delivery method accumulates sent emails in the |
||||
# ActionMailer::Base.deliveries array. |
||||
config.action_mailer.delivery_method = :test |
||||
|
||||
# Print deprecation notices to the stderr. |
||||
config.active_support.deprecation = :stderr |
||||
|
||||
# Raise exceptions for disallowed deprecations. |
||||
config.active_support.disallowed_deprecation = :raise |
||||
|
||||
# Tell Active Support which deprecation messages to disallow. |
||||
config.active_support.disallowed_deprecation_warnings = [] |
||||
|
||||
# Raises error for missing translations. |
||||
# config.i18n.raise_on_missing_translations = true |
||||
|
||||
# Annotate rendered view with file names. |
||||
# config.action_view.annotate_rendered_view_with_filenames = true |
||||
end |
@ -0,0 +1,8 @@
|
||||
# Be sure to restart your server when you modify this file. |
||||
|
||||
# ActiveSupport::Reloader.to_prepare do |
||||
# ApplicationController.renderer.defaults.merge!( |
||||
# http_host: 'example.org', |
||||
# https: false |
||||
# ) |
||||
# end |
@ -0,0 +1,8 @@
|
||||
# Be sure to restart your server when you modify this file. |
||||
|
||||
# You can add backtrace silencers for libraries that you're using but don't wish to see in your backtraces. |
||||
# Rails.backtrace_cleaner.add_silencer { |line| /my_noisy_library/.match?(line) } |
||||
|
||||
# You can also remove all the silencers if you're trying to debug a problem that might stem from framework code |
||||
# by setting BACKTRACE=1 before calling your invocation, like "BACKTRACE=1 ./bin/rails runner 'MyClass.perform'". |
||||
Rails.backtrace_cleaner.remove_silencers! if ENV["BACKTRACE"] |
@ -0,0 +1,30 @@
|
||||
# Be sure to restart your server when you modify this file. |
||||
|
||||
# Define an application-wide content security policy |
||||
# For further information see the following documentation |
||||
# https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Security-Policy |
||||
|
||||
# Rails.application.config.content_security_policy do |policy| |
||||
# policy.default_src :self, :https |
||||
# policy.font_src :self, :https, :data |
||||
# policy.img_src :self, :https, :data |
||||
# policy.object_src :none |
||||
# policy.script_src :self, :https |
||||
# policy.style_src :self, :https |
||||
# # If you are using webpack-dev-server then specify webpack-dev-server host |
||||
# policy.connect_src :self, :https, "http://localhost:3035", "ws://localhost:3035" if Rails.env.development? |
||||
|
||||
# # Specify URI for violation reports |
||||
# # policy.report_uri "/csp-violation-report-endpoint" |
||||
# end |
||||
|
||||
# If you are using UJS then enable automatic nonce generation |
||||
# Rails.application.config.content_security_policy_nonce_generator = -> request { SecureRandom.base64(16) } |
||||
|
||||
# Set the nonce only to specific directives |
||||
# Rails.application.config.content_security_policy_nonce_directives = %w(script-src) |
||||
|
||||
# Report CSP violations to a specified URI |
||||
# For further information see the following documentation: |
||||
# https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Security-Policy-Report-Only |
||||
# Rails.application.config.content_security_policy_report_only = true |
@ -0,0 +1,5 @@
|
||||
# Be sure to restart your server when you modify this file. |
||||
|
||||
# Specify a serializer for the signed and encrypted cookie jars. |
||||
# Valid options are :json, :marshal, and :hybrid. |
||||
Rails.application.config.action_dispatch.cookies_serializer = :json |
@ -0,0 +1,6 @@
|
||||
# Be sure to restart your server when you modify this file. |
||||
|
||||
# Configure sensitive parameters which will be filtered from the log file. |
||||
Rails.application.config.filter_parameters += %i[ |
||||
passw secret token _key crypt salt certificate otp ssn |
||||
] |
@ -0,0 +1,16 @@
|
||||
# Be sure to restart your server when you modify this file. |
||||
|
||||
# Add new inflection rules using the following format. Inflections |
||||
# are locale specific, and you may define rules for as many different |
||||
# locales as you wish. All of these examples are active by default: |
||||
# ActiveSupport::Inflector.inflections(:en) do |inflect| |
||||
# inflect.plural /^(ox)$/i, '\1en' |
||||
# inflect.singular /^(ox)en/i, '\1' |
||||
# inflect.irregular 'person', 'people' |
||||
# inflect.uncountable %w( fish sheep ) |
||||
# end |
||||
|
||||
# These inflection rules are supported but not enabled by default: |
||||
# ActiveSupport::Inflector.inflections(:en) do |inflect| |
||||
# inflect.acronym 'RESTful' |
||||
# end |
@ -0,0 +1,4 @@
|
||||
# Be sure to restart your server when you modify this file. |
||||
|
||||
# Add new mime types for use in respond_to blocks: |
||||
# Mime::Type.register "text/richtext", :rtf |
@ -0,0 +1,11 @@
|
||||
# Define an application-wide HTTP permissions policy. For further |
||||
# information see https://developers.google.com/web/updates/2018/06/feature-policy |
||||
# |
||||
# Rails.application.config.permissions_policy do |f| |
||||
# f.camera :none |
||||
# f.gyroscope :none |
||||
# f.microphone :none |
||||
# f.usb :none |
||||
# f.fullscreen :self |
||||
# f.payment :self, "https://secure.example.com" |
||||
# end |
@ -0,0 +1,14 @@
|
||||
# Be sure to restart your server when you modify this file. |
||||
|
||||
# This file contains settings for ActionController::ParamsWrapper which |
||||
# is enabled by default. |
||||
|
||||
# Enable parameter wrapping for JSON. You can disable this by setting :format to an empty array. |
||||
ActiveSupport.on_load(:action_controller) do |
||||
wrap_parameters format: [:json] |
||||
end |
||||
|
||||
# To enable root element in JSON for ActiveRecord objects. |
||||
# ActiveSupport.on_load(:active_record) do |
||||
# self.include_root_in_json = true |
||||
# end |
@ -0,0 +1,33 @@
|
||||
# Files in the config/locales directory are used for internationalization |
||||
# and are automatically loaded by Rails. If you want to use locales other |
||||
# than English, add the necessary files in this directory. |
||||
# |
||||
# To use the locales, use `I18n.t`: |
||||
# |
||||
# I18n.t 'hello' |
||||
# |
||||
# In views, this is aliased to just `t`: |
||||
# |
||||
# <%= t('hello') %> |
||||
# |
||||
# To use a different locale, set it with `I18n.locale`: |
||||
# |
||||
# I18n.locale = :es |
||||
# |
||||
# This would use the information in config/locales/es.yml. |
||||
# |
||||
# The following keys must be escaped otherwise they will not be retrieved by |
||||
# the default I18n backend: |
||||
# |
||||
# true, false, on, off, yes, no |
||||
# |
||||
# Instead, surround them with single quotes. |
||||
# |
||||
# en: |
||||
# 'true': 'foo' |
||||
# |
||||
# To learn more, please read the Rails Internationalization guide |
||||
# available at https://guides.rubyonrails.org/i18n.html. |
||||
|
||||
en: |
||||
hello: "Hello world" |
@ -0,0 +1,43 @@
|
||||
# Puma can serve each request in a thread from an internal thread pool. |
||||
# The `threads` method setting takes two numbers: a minimum and maximum. |
||||
# Any libraries that use thread pools should be configured to match |
||||
# the maximum value specified for Puma. Default is set to 5 threads for minimum |
||||
# and maximum; this matches the default thread size of Active Record. |
||||
# |
||||
max_threads_count = ENV.fetch("RAILS_MAX_THREADS") { 5 } |
||||
min_threads_count = ENV.fetch("RAILS_MIN_THREADS") { max_threads_count } |
||||
threads min_threads_count, max_threads_count |
||||
|
||||
# Specifies the `worker_timeout` threshold that Puma will use to wait before |
||||
# terminating a worker in development environments. |
||||
# |
||||
worker_timeout 3600 if ENV.fetch("RAILS_ENV", "development") == "development" |
||||
|
||||
# Specifies the `port` that Puma will listen on to receive requests; default is 3000. |
||||
# |
||||
port ENV.fetch("PORT") { 3000 } |
||||
|
||||
# Specifies the `environment` that Puma will run in. |
||||
# |
||||
environment ENV.fetch("RAILS_ENV") { "development" } |
||||
|
||||
# Specifies the `pidfile` that Puma will use. |
||||
pidfile ENV.fetch("PIDFILE") { "tmp/pids/server.pid" } |
||||
|
||||
# Specifies the number of `workers` to boot in clustered mode. |
||||
# Workers are forked web server processes. If using threads and workers together |
||||
# the concurrency of the application would be max `threads` * `workers`. |
||||
# Workers do not work on JRuby or Windows (both of which do not support |
||||
# processes). |
||||
# |
||||
# workers ENV.fetch("WEB_CONCURRENCY") { 2 } |
||||
|
||||
# Use the `preload_app!` method when specifying a `workers` number. |
||||
# This directive tells Puma to first boot the application and load code |
||||
# before forking the application. This takes advantage of Copy On Write |
||||
# process behavior so workers use less memory. |
||||
# |
||||
# preload_app! |
||||
|
||||
# Allow puma to be restarted by `rails restart` command. |
||||
plugin :tmp_restart |
@ -0,0 +1,6 @@
|
||||
Rails.application.routes.draw do |
||||
# For details on the DSL available within this file, see https://guides.rubyonrails.org/routing.html |
||||
get "about", to: "about#index" |
||||
get "/", to: "test#index" |
||||
get "form", to: "form#index" |
||||
end |
@ -0,0 +1,34 @@
|
||||
test: |
||||
service: Disk |
||||
root: <%= Rails.root.join("tmp/storage") %> |
||||
|
||||
local: |
||||
service: Disk |
||||
root: <%= Rails.root.join("storage") %> |
||||
|
||||
# Use rails credentials:edit to set the AWS secrets (as aws:access_key_id|secret_access_key) |
||||
# amazon: |
||||
# service: S3 |
||||
# access_key_id: <%= Rails.application.credentials.dig(:aws, :access_key_id) %> |
||||
# secret_access_key: <%= Rails.application.credentials.dig(:aws, :secret_access_key) %> |
||||
# region: us-east-1 |
||||
# bucket: your_own_bucket |
||||
|
||||
# Remember not to checkin your GCS keyfile to a repository |
||||
# google: |
||||
# service: GCS |
||||
# project: your_project |
||||
# credentials: <%= Rails.root.join("path/to/gcs.keyfile") %> |
||||
# bucket: your_own_bucket |
||||
|
||||
# Use rails credentials:edit to set the Azure Storage secret (as azure_storage:storage_access_key) |
||||
# microsoft: |
||||
# service: AzureStorage |
||||
# storage_account_name: your_account_name |
||||
# storage_access_key: <%= Rails.application.credentials.dig(:azure_storage, :storage_access_key) %> |
||||
# container: your_container_name |
||||
|
||||
# mirror: |
||||
# service: Mirror |
||||
# primary: local |
||||
# mirrors: [ amazon, google, microsoft ] |
@ -0,0 +1,5 @@
|
||||
process.env.NODE_ENV = process.env.NODE_ENV || 'development' |
||||
|
||||
const environment = require('./environment') |
||||
|
||||
module.exports = environment.toWebpackConfig() |
@ -0,0 +1,3 @@
|
||||
const { environment } = require('@rails/webpacker') |
||||
|
||||
module.exports = environment |
@ -0,0 +1,5 @@
|
||||
process.env.NODE_ENV = process.env.NODE_ENV || 'production' |
||||
|
||||
const environment = require('./environment') |
||||
|
||||
module.exports = environment.toWebpackConfig() |
@ -0,0 +1,5 @@
|
||||
process.env.NODE_ENV = process.env.NODE_ENV || 'development' |
||||
|
||||
const environment = require('./environment') |
||||
|
||||
module.exports = environment.toWebpackConfig() |
@ -0,0 +1,92 @@
|
||||
# Note: You must restart bin/webpack-dev-server for changes to take effect |
||||
|
||||
default: &default |
||||
source_path: app/javascript |
||||
source_entry_path: packs |
||||
public_root_path: public |
||||
public_output_path: packs |
||||
cache_path: tmp/cache/webpacker |
||||
webpack_compile_output: true |
||||
|
||||
# Additional paths webpack should lookup modules |
||||
# ['app/assets', 'engine/foo/app/assets'] |
||||
additional_paths: ['node_modules/govuk-frontend/govuk'] |
||||
|
||||
# Reload manifest.json on all requests so we reload latest compiled packs |
||||
cache_manifest: false |
||||
|
||||
# Extract and emit a css file |
||||
extract_css: false |
||||
|
||||
static_assets_extensions: |
||||
- .jpg |
||||
- .jpeg |
||||
- .png |
||||
- .gif |
||||
- .tiff |
||||
- .ico |
||||
- .svg |
||||
- .eot |
||||
- .otf |
||||
- .ttf |
||||
- .woff |
||||
- .woff2 |
||||
|
||||
extensions: |
||||
- .mjs |
||||
- .js |
||||
- .sass |
||||
- .scss |
||||
- .css |
||||
- .module.sass |
||||
- .module.scss |
||||
- .module.css |
||||
- .png |
||||
- .svg |
||||
- .gif |
||||
- .jpeg |
||||
- .jpg |
||||
|
||||
development: |
||||
<<: *default |
||||
compile: true |
||||
|
||||
# Reference: https://webpack.js.org/configuration/dev-server/ |
||||
dev_server: |
||||
https: false |
||||
host: localhost |
||||
port: 3035 |
||||
public: localhost:3035 |
||||
hmr: false |
||||
# Inline should be set to true if using HMR |
||||
inline: true |
||||
overlay: true |
||||
compress: true |
||||
disable_host_check: true |
||||
use_local_ip: false |
||||
quiet: false |
||||
pretty: false |
||||
headers: |
||||
'Access-Control-Allow-Origin': '*' |
||||
watch_options: |
||||
ignored: '**/node_modules/**' |
||||
|
||||
|
||||
test: |
||||
<<: *default |
||||
compile: true |
||||
|
||||
# Compile test packs to a separate directory |
||||
public_output_path: packs-test |
||||
|
||||
production: |
||||
<<: *default |
||||
|
||||
# Production depends on precompilation of packs prior to booting for performance. |
||||
compile: false |
||||
|
||||
# Extract and emit a css file |
||||
extract_css: true |
||||
|
||||
# Cache manifest.json for performance |
||||
cache_manifest: true |
@ -0,0 +1,7 @@
|
||||
# This file should contain all the record creation needed to seed the database with its default values. |
||||
# The data can then be loaded with the bin/rails db:seed command (or created alongside the database with db:setup). |
||||
# |
||||
# Examples: |
||||
# |
||||
# movies = Movie.create([{ name: 'Star Wars' }, { name: 'Lord of the Rings' }]) |
||||
# Character.create(name: 'Luke', movie: movies.first) |
@ -0,0 +1,38 @@
|
||||
version: '3.6' |
||||
|
||||
volumes: |
||||
dbdata: |
||||
|
||||
services: |
||||
db: |
||||
image: postgres:13.3-alpine |
||||
restart: always |
||||
# To preserve data between runs of docker-compose, we mount a folder from the host machine. |
||||
volumes: |
||||
- dbdata:/var/lib/postgresql/data |
||||
ports: |
||||
- 5433:5432 # Mapped to 5433 in case Postgres is already running locally on 5432 |
||||
environment: |
||||
- POSTGRES_PASSWORD=password |
||||
- POSTGRES_USER=postgres |
||||
- POSTGRES_DB=data_collector |
||||
|
||||
app: |
||||
build: |
||||
context: . |
||||
dockerfile: ./Dockerfile |
||||
args: |
||||
GIT_COMMIT_SHA: DOCKER_COMPOSE_GIT_COMMIT_SHA |
||||
ports: |
||||
- 8080:8080 |
||||
depends_on: |
||||
- db |
||||
environment: |
||||
- DB_HOST=db |
||||
- DB_DATABASE=data_collector |
||||
- DB_USERNAME=postgres |
||||
- DB_PASSWORD=password |
||||
- RAILS_ENV=production |
||||
- RAILS_SERVE_STATIC_FILES=true |
||||
- RAILS_LOG_TO_STDOUT=true |
||||
- SECRET_KEY_BASE=abcd1234 |
@ -0,0 +1,17 @@
|
||||
{ |
||||
"name": "data-collector", |
||||
"private": true, |
||||
"dependencies": { |
||||
"@rails/actioncable": "^6.0.0", |
||||
"@rails/activestorage": "^6.0.0", |
||||
"@rails/ujs": "^6.0.0", |
||||
"@rails/webpacker": "5.4.0", |
||||
"govuk-frontend": "^3.13.0", |
||||
"webpack": "^4.46.0", |
||||
"webpack-cli": "^3.3.12" |
||||
}, |
||||
"version": "0.1.0", |
||||
"devDependencies": { |
||||
"webpack-dev-server": "^3.11.2" |
||||
} |
||||
} |
@ -0,0 +1,12 @@
|
||||
module.exports = { |
||||
plugins: [ |
||||
require('postcss-import'), |
||||
require('postcss-flexbugs-fixes'), |
||||
require('postcss-preset-env')({ |
||||
autoprefixer: { |
||||
flexbox: 'no-2009' |
||||
}, |
||||
stage: 3 |
||||
}) |
||||
] |
||||
} |
@ -0,0 +1,67 @@
|
||||
<!DOCTYPE html> |
||||
<html> |
||||
<head> |
||||
<title>The page you were looking for doesn't exist (404)</title> |
||||
<meta name="viewport" content="width=device-width,initial-scale=1"> |
||||
<style> |
||||
.rails-default-error-page { |
||||
background-color: #EFEFEF; |
||||
color: #2E2F30; |
||||
text-align: center; |
||||
font-family: arial, sans-serif; |
||||
margin: 0; |
||||
} |
||||
|
||||
.rails-default-error-page div.dialog { |
||||
width: 95%; |
||||
max-width: 33em; |
||||
margin: 4em auto 0; |
||||
} |
||||
|
||||
.rails-default-error-page div.dialog > div { |
||||
border: 1px solid #CCC; |
||||
border-right-color: #999; |
||||
border-left-color: #999; |
||||
border-bottom-color: #BBB; |
||||
border-top: #B00100 solid 4px; |
||||
border-top-left-radius: 9px; |
||||
border-top-right-radius: 9px; |
||||
background-color: white; |
||||
padding: 7px 12% 0; |
||||
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17); |
||||
} |
||||
|
||||
.rails-default-error-page h1 { |
||||
font-size: 100%; |
||||
color: #730E15; |
||||
line-height: 1.5em; |
||||
} |
||||
|
||||
.rails-default-error-page div.dialog > p { |
||||
margin: 0 0 1em; |
||||
padding: 1em; |
||||
background-color: #F7F7F7; |
||||
border: 1px solid #CCC; |
||||
border-right-color: #999; |
||||
border-left-color: #999; |
||||
border-bottom-color: #999; |
||||
border-bottom-left-radius: 4px; |
||||
border-bottom-right-radius: 4px; |
||||
border-top-color: #DADADA; |
||||
color: #666; |
||||
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17); |
||||
} |
||||
</style> |
||||
</head> |
||||
|
||||
<body class="rails-default-error-page"> |
||||
<!-- This file lives in public/404.html --> |
||||
<div class="dialog"> |
||||
<div> |
||||
<h1>The page you were looking for doesn't exist.</h1> |
||||
<p>You may have mistyped the address or the page may have moved.</p> |
||||
</div> |
||||
<p>If you are the application owner check the logs for more information.</p> |
||||
</div> |
||||
</body> |
||||
</html> |
@ -0,0 +1,67 @@
|
||||
<!DOCTYPE html> |
||||
<html> |
||||
<head> |
||||
<title>The change you wanted was rejected (422)</title> |
||||
<meta name="viewport" content="width=device-width,initial-scale=1"> |
||||
<style> |
||||
.rails-default-error-page { |
||||
background-color: #EFEFEF; |
||||
color: #2E2F30; |
||||
text-align: center; |
||||
font-family: arial, sans-serif; |
||||
margin: 0; |
||||
} |
||||
|
||||
.rails-default-error-page div.dialog { |
||||
width: 95%; |
||||
max-width: 33em; |
||||
margin: 4em auto 0; |
||||
} |
||||
|
||||
.rails-default-error-page div.dialog > div { |
||||
border: 1px solid #CCC; |
||||
border-right-color: #999; |
||||
border-left-color: #999; |
||||
border-bottom-color: #BBB; |
||||
border-top: #B00100 solid 4px; |
||||
border-top-left-radius: 9px; |
||||
border-top-right-radius: 9px; |
||||
background-color: white; |
||||
padding: 7px 12% 0; |
||||
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17); |
||||
} |
||||
|
||||
.rails-default-error-page h1 { |
||||
font-size: 100%; |
||||
color: #730E15; |
||||
line-height: 1.5em; |
||||
} |
||||
|
||||
.rails-default-error-page div.dialog > p { |
||||
margin: 0 0 1em; |
||||
padding: 1em; |
||||
background-color: #F7F7F7; |
||||
border: 1px solid #CCC; |
||||
border-right-color: #999; |
||||
border-left-color: #999; |
||||
border-bottom-color: #999; |
||||
border-bottom-left-radius: 4px; |
||||
border-bottom-right-radius: 4px; |
||||
border-top-color: #DADADA; |
||||
color: #666; |
||||
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17); |
||||
} |
||||
</style> |
||||
</head> |
||||
|
||||
<body class="rails-default-error-page"> |
||||
<!-- This file lives in public/422.html --> |
||||
<div class="dialog"> |
||||
<div> |
||||
<h1>The change you wanted was rejected.</h1> |
||||
<p>Maybe you tried to change something you didn't have access to.</p> |
||||
</div> |
||||
<p>If you are the application owner check the logs for more information.</p> |
||||
</div> |
||||
</body> |
||||
</html> |
@ -0,0 +1,66 @@
|
||||
<!DOCTYPE html> |
||||
<html> |
||||
<head> |
||||
<title>We're sorry, but something went wrong (500)</title> |
||||
<meta name="viewport" content="width=device-width,initial-scale=1"> |
||||
<style> |
||||
.rails-default-error-page { |
||||
background-color: #EFEFEF; |
||||
color: #2E2F30; |
||||
text-align: center; |
||||
font-family: arial, sans-serif; |
||||
margin: 0; |
||||
} |
||||
|
||||
.rails-default-error-page div.dialog { |
||||
width: 95%; |
||||
max-width: 33em; |
||||
margin: 4em auto 0; |
||||
} |
||||
|
||||
.rails-default-error-page div.dialog > div { |
||||
border: 1px solid #CCC; |
||||
border-right-color: #999; |
||||
border-left-color: #999; |
||||
border-bottom-color: #BBB; |
||||
border-top: #B00100 solid 4px; |
||||
border-top-left-radius: 9px; |
||||
border-top-right-radius: 9px; |
||||
background-color: white; |
||||
padding: 7px 12% 0; |
||||
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17); |
||||
} |
||||
|
||||
.rails-default-error-page h1 { |
||||
font-size: 100%; |
||||
color: #730E15; |
||||
line-height: 1.5em; |
||||
} |
||||
|
||||
.rails-default-error-page div.dialog > p { |
||||
margin: 0 0 1em; |
||||
padding: 1em; |
||||
background-color: #F7F7F7; |
||||
border: 1px solid #CCC; |
||||
border-right-color: #999; |
||||
border-left-color: #999; |
||||
border-bottom-color: #999; |
||||
border-bottom-left-radius: 4px; |
||||
border-bottom-right-radius: 4px; |
||||
border-top-color: #DADADA; |
||||
color: #666; |
||||
box-shadow: 0 3px 8px rgba(50, 50, 50, 0.17); |
||||
} |
||||
</style> |
||||
</head> |
||||
|
||||
<body class="rails-default-error-page"> |
||||
<!-- This file lives in public/500.html --> |
||||
<div class="dialog"> |
||||
<div> |
||||
<h1>We're sorry, but something went wrong.</h1> |
||||
</div> |
||||
<p>If you are the application owner check the logs for more information.</p> |
||||
</div> |
||||
</body> |
||||
</html> |
@ -0,0 +1 @@
|
||||
# See https://www.robotstxt.org/robotstxt.html for documentation on how to use the robots.txt file |
@ -0,0 +1,13 @@
|
||||
require "rails_helper" |
||||
|
||||
# Test Controller intital test |
||||
RSpec.describe TestController, type: :controller do |
||||
let(:valid_session) { {} } |
||||
|
||||
describe "GET #index" do |
||||
it "returns a success response" do |
||||
get :index, params: {}, session: valid_session |
||||
expect(response).to be_successful # be_successful expects a HTTP Status code of 200 |
||||
end |
||||
end |
||||
end |
@ -0,0 +1,8 @@
|
||||
require "rails_helper" |
||||
RSpec.describe "Test Features" do |
||||
it "Displays the name of the app" do |
||||
visit("/form") |
||||
expect(page).to have_field("Age") |
||||
expect(page).to have_button("Continue") |
||||
end |
||||
end |
@ -0,0 +1,14 @@
|
||||
require "rails_helper" |
||||
RSpec.describe "Test Features" do |
||||
it "Displays the name of the app" do |
||||
visit("/") |
||||
expect(page).to have_content("Share Lettings and Sales for Social Housing in England Data with MHCLG") |
||||
end |
||||
|
||||
it "Links to the About page" do |
||||
visit("/") |
||||
click_link("About") |
||||
expect(current_path).to eql("/about") |
||||
expect(page).to have_content("About") |
||||
end |
||||
end |
@ -0,0 +1,65 @@
|
||||
# This file is copied to spec/ when you run 'rails generate rspec:install' |
||||
require "spec_helper" |
||||
ENV["RAILS_ENV"] ||= "test" |
||||
require File.expand_path("../config/environment", __dir__) |
||||
# Prevent database truncation if the environment is production |
||||
abort("The Rails environment is running in production mode!") if Rails.env.production? |
||||
require "rspec/rails" |
||||
require "capybara/rspec" |
||||
# Add additional requires below this line. Rails is not loaded until this point! |
||||
|
||||
# Requires supporting ruby files with custom matchers and macros, etc, in |
||||
# spec/support/ and its subdirectories. Files matching `spec/**/*_spec.rb` are |
||||
# run as spec files by default. This means that files in spec/support that end |
||||
# in _spec.rb will both be required and run as specs, causing the specs to be |
||||
# run twice. It is recommended that you do not name files matching this glob to |
||||
# end with _spec.rb. You can configure this pattern with the --pattern |
||||
# option on the command line or in ~/.rspec, .rspec or `.rspec-local`. |
||||
# |
||||
# The following line is provided for convenience purposes. It has the downside |
||||
# of increasing the boot-up time by auto-requiring all files in the support |
||||
# directory. Alternatively, in the individual `*_spec.rb` files, manually |
||||
# require only the support files necessary. |
||||
# |
||||
# Dir[Rails.root.join('spec', 'support', '**', '*.rb')].sort.each { |f| require f } |
||||
|
||||
# Checks for pending migrations and applies them before tests are run. |
||||
# If you are not using ActiveRecord, you can remove these lines. |
||||
begin |
||||
ActiveRecord::Migration.maintain_test_schema! |
||||
rescue ActiveRecord::PendingMigrationError => e |
||||
puts e.to_s.strip |
||||
exit 1 |
||||
end |
||||
RSpec.configure do |config| |
||||
# Remove this line if you're not using ActiveRecord or ActiveRecord fixtures |
||||
config.fixture_path = "#{::Rails.root}/spec/fixtures" |
||||
|
||||
# If you're not using ActiveRecord, or you'd prefer not to run each of your |
||||
# examples within a transaction, remove the following line or assign false |
||||
# instead of true. |
||||
config.use_transactional_fixtures = true |
||||
|
||||
# You can uncomment this line to turn off ActiveRecord support entirely. |
||||
# config.use_active_record = false |
||||
|
||||
# RSpec Rails can automatically mix in different behaviours to your tests |
||||
# based on their file location, for example enabling you to call `get` and |
||||
# `post` in specs under `spec/controllers`. |
||||
# |
||||
# You can disable this behaviour by removing the line below, and instead |
||||
# explicitly tag your specs with their type, e.g.: |
||||
# |
||||
# RSpec.describe UsersController, type: :controller do |
||||
# # ... |
||||
# end |
||||
# |
||||
# The different available types are documented in the features, such as in |
||||
# https://relishapp.com/rspec/rspec-rails/docs |
||||
config.infer_spec_type_from_file_location! |
||||
|
||||
# Filter lines from Rails gems in backtraces. |
||||
config.filter_rails_from_backtrace! |
||||
# arbitrary gems may also be filtered via: |
||||
# config.filter_gems_from_backtrace("gem name") |
||||
end |
@ -0,0 +1,94 @@
|
||||
# This file was generated by the `rails generate rspec:install` command. Conventionally, all |
||||
# specs live under a `spec` directory, which RSpec adds to the `$LOAD_PATH`. |
||||
# The generated `.rspec` file contains `--require spec_helper` which will cause |
||||
# this file to always be loaded, without a need to explicitly require it in any |
||||
# files. |
||||
# |
||||
# Given that it is always loaded, you are encouraged to keep this file as |
||||
# light-weight as possible. Requiring heavyweight dependencies from this file |
||||
# will add to the boot time of your test suite on EVERY test run, even for an |
||||
# individual file that may not need all of that loaded. Instead, consider making |
||||
# a separate helper file that requires the additional dependencies and performs |
||||
# the additional setup, and require it from the spec files that actually need |
||||
# it. |
||||
# |
||||
# See http://rubydoc.info/gems/rspec-core/RSpec/Core/Configuration |
||||
RSpec.configure do |config| |
||||
# rspec-expectations config goes here. You can use an alternate |
||||
# assertion/expectation library such as wrong or the stdlib/minitest |
||||
# assertions if you prefer. |
||||
config.expect_with :rspec do |expectations| |
||||
# This option will default to `true` in RSpec 4. It makes the `description` |
||||
# and `failure_message` of custom matchers include text for helper methods |
||||
# defined using `chain`, e.g.: |
||||
# be_bigger_than(2).and_smaller_than(4).description |
||||
# # => "be bigger than 2 and smaller than 4" |
||||
# ...rather than: |
||||
# # => "be bigger than 2" |
||||
expectations.include_chain_clauses_in_custom_matcher_descriptions = true |
||||
end |
||||
|
||||
# rspec-mocks config goes here. You can use an alternate test double |
||||
# library (such as bogus or mocha) by changing the `mock_with` option here. |
||||
config.mock_with :rspec do |mocks| |
||||
# Prevents you from mocking or stubbing a method that does not exist on |
||||
# a real object. This is generally recommended, and will default to |
||||
# `true` in RSpec 4. |
||||
mocks.verify_partial_doubles = true |
||||
end |
||||
|
||||
# This option will default to `:apply_to_host_groups` in RSpec 4 (and will |
||||
# have no way to turn it off -- the option exists only for backwards |
||||
# compatibility in RSpec 3). It causes shared context metadata to be |
||||
# inherited by the metadata hash of host groups and examples, rather than |
||||
# triggering implicit auto-inclusion in groups with matching metadata. |
||||
config.shared_context_metadata_behavior = :apply_to_host_groups |
||||
|
||||
# The settings below are suggested to provide a good initial experience |
||||
# with RSpec, but feel free to customize to your heart's content. |
||||
# # This allows you to limit a spec run to individual examples or groups |
||||
# # you care about by tagging them with `:focus` metadata. When nothing |
||||
# # is tagged with `:focus`, all examples get run. RSpec also provides |
||||
# # aliases for `it`, `describe`, and `context` that include `:focus` |
||||
# # metadata: `fit`, `fdescribe` and `fcontext`, respectively. |
||||
# config.filter_run_when_matching :focus |
||||
# |
||||
# # Allows RSpec to persist some state between runs in order to support |
||||
# # the `--only-failures` and `--next-failure` CLI options. We recommend |
||||
# # you configure your source control system to ignore this file. |
||||
# config.example_status_persistence_file_path = "spec/examples.txt" |
||||
# |
||||
# # Limits the available syntax to the non-monkey patched syntax that is |
||||
# # recommended. For more details, see: |
||||
# # - http://rspec.info/blog/2012/06/rspecs-new-expectation-syntax/ |
||||
# # - http://www.teaisaweso.me/blog/2013/05/27/rspecs-new-message-expectation-syntax/ |
||||
# # - http://rspec.info/blog/2014/05/notable-changes-in-rspec-3/#zero-monkey-patching-mode |
||||
# config.disable_monkey_patching! |
||||
# |
||||
# # Many RSpec users commonly either run the entire suite or an individual |
||||
# # file, and it's useful to allow more verbose output when running an |
||||
# # individual spec file. |
||||
# if config.files_to_run.one? |
||||
# # Use the documentation formatter for detailed output, |
||||
# # unless a formatter has already been configured |
||||
# # (e.g. via a command-line flag). |
||||
# config.default_formatter = "doc" |
||||
# end |
||||
# |
||||
# # Print the 10 slowest examples and example groups at the |
||||
# # end of the spec run, to help surface which specs are running |
||||
# # particularly slow. |
||||
# config.profile_examples = 10 |
||||
# |
||||
# # Run specs in random order to surface order dependencies. If you find an |
||||
# # order dependency and want to debug it, you can fix the order by providing |
||||
# # the seed, which is printed after each run. |
||||
# # --seed 1234 |
||||
# config.order = :random |
||||
# |
||||
# # Seed global randomization in this process using the `--seed` CLI option. |
||||
# # Setting this allows you to use `--seed` to deterministically reproduce |
||||
# # test failures related to randomization by passing the same `--seed` value |
||||
# # as the one that triggered the failure. |
||||
# Kernel.srand config.seed |
||||
end |
Loading…
Reference in new issue