diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml index c9ee4b626e..4410fcd05f 100644 --- a/.github/workflows/lint.yml +++ b/.github/workflows/lint.yml @@ -1,7 +1,14 @@ name: Linting on: - - push - - pull_request + push: + pull_request: + types: + # defaults + - opened + - synchronize + - reopened + # custom + - ready_for_review # required for Github-created PRs jobs: rubocop: @@ -12,7 +19,7 @@ jobs: RUBOCOP_CACHE_ROOT: ".rubocop-cache" BUNDLE_WITHOUT: "cucumber deployment profile development default test" steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v4 - name: Set up Ruby uses: ruby/setup-ruby@v1 with: @@ -20,14 +27,14 @@ jobs: # Establish a cache of rubocop cache to improve performance # ${{ env.RUBOCOP_CACHE_ROOT }} - name: Setup node - uses: actions/setup-node@v3 + uses: actions/setup-node@v4 with: node-version-file: ".nvmrc" cache: "yarn" - name: Set up yarn - run: yarn + run: yarn install - name: Cache cops - uses: actions/cache@v2 + uses: actions/cache@v4 with: path: | ${{ env.RUBOCOP_CACHE_ROOT }} @@ -46,13 +53,14 @@ jobs: # and parallel to try and improve speed - name: Run rubocop run: bundle exec rubocop --extra-details --display-style-guide --parallel --format github --format progress + eslint: name: EsLint runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v4 - name: Setup node - uses: actions/setup-node@v3 + uses: actions/setup-node@v4 with: node-version-file: ".nvmrc" cache: "yarn" diff --git a/.github/workflows/lint_yard_docs.yml b/.github/workflows/lint_yard_docs.yml index a4a3685061..d93fb8b1b6 100644 --- a/.github/workflows/lint_yard_docs.yml +++ b/.github/workflows/lint_yard_docs.yml @@ -1,7 +1,14 @@ name: Lint documentation on: - - push - - pull_request + push: + pull_request: + types: + # defaults + - opened + - synchronize + - reopened + # custom + - ready_for_review # required for Github-created PRs jobs: yard-junk: diff --git a/.github/workflows/ruby_test.yml b/.github/workflows/ruby_test.yml index d8da15e6b5..34f98ead59 100644 --- a/.github/workflows/ruby_test.yml +++ b/.github/workflows/ruby_test.yml @@ -16,8 +16,15 @@ env: ######## on: - - push - - pull_request + push: + pull_request: + types: + # defaults + - opened + - synchronize + - reopened + # custom + - ready_for_review # required for Github-created PRs jobs: rake_tests: diff --git a/.github/workflows/update-rubocop.yml b/.github/workflows/update-rubocop.yml index 80952c40d4..513b9bc067 100644 --- a/.github/workflows/update-rubocop.yml +++ b/.github/workflows/update-rubocop.yml @@ -29,9 +29,9 @@ jobs: if: (github.repository_owner == 'sanger') # On the sanger fork only runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v4 - name: Setup node - uses: actions/setup-node@v3 + uses: actions/setup-node@v4 with: node-version-file: ".nvmrc" cache: "yarn" @@ -50,10 +50,12 @@ jobs: run: bundle exec rubocop --auto-correct --disable-uncorrectable # https://github.com/marketplace/actions/create-pull-request - name: Create Pull Request - uses: peter-evans/create-pull-request@v3 + uses: peter-evans/create-pull-request@v7 with: title: Automatic Rubocop update branch: gh_action/update_rubocop + labels: Technical Debt + draft: always-true # https://github.com/peter-evans/create-pull-request/blob/main/docs/concepts-guidelines.md#workarounds-to-trigger-further-workflow-runs delete-branch: true body: | Automatic update via https://github.com/sanger/sequencescape/blob/develop/.github/workflows/update_rubocop.yml @@ -61,3 +63,5 @@ jobs: This cop will trigger safe-autocorrect for new cops, and will add inline rubocop:todo for other cops. Please sanity check any changes before merging in. + + Click `Ready for review` to trigger the CI checks. diff --git a/.release-version b/.release-version index f6e3abc805..b08f99bfbe 100644 --- a/.release-version +++ b/.release-version @@ -1 +1 @@ -14.42.1 +14.42.2 diff --git a/.rubocop.yml b/.rubocop.yml index 41e6ec50bd..6556c8a223 100644 --- a/.rubocop.yml +++ b/.rubocop.yml @@ -6,18 +6,14 @@ require: - rubocop-performance - rubocop-rails - rubocop-rspec + - rubocop-rspec_rails + - rubocop-capybara + - rubocop-factory_bot + +inherit_mode: + merge: + - Exclude -RSpec/AggregateExamples: - # Aggregate examples can be useful, but the cop gets into nasty battles with - # other Spec cops, and is only really of value in expensive tests. - Enabled: false -# Added exclude because api and feature specs do not have a specific class. -RSpec/DescribeClass: - Exclude: - - "spec/requests/**/*.rb" - - "spec/api/**/*.rb" - - "spec/features/**/*.rb" - - "spec/views/**/*.rb" AllCops: NewCops: enable Exclude: @@ -32,6 +28,18 @@ AllCops: - node_modules/**/* - tmp/**/* +RSpec/AggregateExamples: + # Aggregate examples can be useful, but the cop gets into nasty battles with + # other Spec cops, and is only really of value in expensive tests. + Enabled: false +# Added exclude because api and feature specs do not have a specific class. +RSpec/DescribeClass: + Exclude: + - "spec/requests/**/*.rb" + - "spec/api/**/*.rb" + - "spec/features/**/*.rb" + - "spec/views/**/*.rb" + Rails/SkipsModelValidations: Exclude: - "db/migrate/*.rb" @@ -48,6 +56,11 @@ Rails: Lint/AmbiguousRegexpLiteral: Exclude: - features/support/step_definitions/**/* + +# Only use shorthand hash syntax when all keys match the variables for better readability +Style/HashSyntax: + EnforcedShorthandSyntax: consistent + # Enforces 1234565789 as 123_456_789: While nice when dealing with actual big # numbers, we're more likely to see it shout at us about barcodes. Style/NumericLiterals: @@ -154,7 +167,7 @@ Metrics/ClassLength: Exclude: - "spec/**/*" - "test/**/*" -RSpec/Rails/AvoidSetupHook: +RSpecRails/AvoidSetupHook: Exclude: - "test/**/*" @@ -173,14 +186,19 @@ Rails/RedundantPresenceValidationOnBelongsTo: Rails/UniqueValidationWithoutIndex: Enabled: false -# Disabling newly introduced cops until we have time to sort out the offenses -FactoryBot/ConsistentParenthesesStyle: +# Factory Bot +FactoryBot/FactoryAssociationWithStrategy: Enabled: false +# Capybara +Capybara/ClickLinkOrButtonStyle: + Enabled: false + +# Disabling newly introduced cops until we have time to sort out the offenses Rails/I18nLocaleTexts: # new in 2.14 Enabled: false -RSpec/Rails/InferredSpecType: # new in 2.14 +RSpecRails/InferredSpecType: # new in 2.14 Enabled: false Lint/NonAtomicFileOperation: # new in 1.31 @@ -202,12 +220,6 @@ RSpec/SpecFilePathFormat: RSpec/PendingWithoutReason: Enabled: false -Capybara/ClickLinkOrButtonStyle: - Enabled: false - -FactoryBot/FactoryAssociationWithStrategy: - Enabled: false - Performance/MapMethodChain: Enabled: false @@ -216,20 +228,5 @@ Rails/ThreeStateBooleanColumn: RSpec/ExpectInHook: Enabled: false - # New in Ruby 3.2 upgrade - -Naming/BlockForwarding: - Enabled: false - -Style/ArgumentsForwarding: - Enabled: false - -Style/ArrayIntersect: - Enabled: false - -Style/EmptyMethod: - Enabled: false - -Style/HashSyntax: - Enabled: false +# Added to Rubocop Todo and handling from there diff --git a/.rubocop_todo.yml b/.rubocop_todo.yml index a63c3341a5..f0100b6877 100644 --- a/.rubocop_todo.yml +++ b/.rubocop_todo.yml @@ -1,38 +1,11 @@ # This configuration was generated by -# `rubocop --auto-gen-config --exclude-limit 10000` -# on 2024-03-15 15:37:36 UTC using RuboCop version 1.61.0. +# `rubocop --auto-gen-config --no-exclude-limit` +# on 2024-09-27 12:02:58 UTC using RuboCop version 1.66.1. # The point is for the user to remove these configuration records # one by one as the offenses are removed from the code base. # Note that changes in the inspected code, or installation of new # versions of RuboCop, may require this file to be generated again. -# Offense count: 17 -# This cop supports safe autocorrection (--autocorrect). -# Configuration parameters: EnforcedStyle. -# SupportedStyles: have_no, not_to -Capybara/NegationMatcher: - Exclude: - - 'features/support/step_definitions/web_steps.rb' - - 'spec/features/assets/asset_submission_spec.rb' - - 'spec/features/patient_consent_withdrawl_spec.rb' - - 'spec/features/pipelines/cherrypick/cherrypick_pipeline_spec.rb' - - 'spec/features/pipelines/sequencing/following_a_sequencing_pipeline_spec.rb' - - 'spec/features/sample_logistics/lab/stock_stamping_spec.rb' - - 'spec/features/sample_manifests/create_manifest_spec.rb' - - 'spec/features/shared_examples/sequencing.rb' - - 'spec/features/studies/change_study_roles_spec.rb' - - 'spec/features/studies/create_study_spec.rb' - - 'spec/features/studies/manage_study_spec.rb' - - 'spec/features/studies/view_study_request_links_spec.rb' - - 'spec/helpers/deprecation_helper_spec.rb' - -# Offense count: 1 -# This cop supports safe autocorrection (--autocorrect). -# Configuration parameters: DefaultSelector. -Capybara/RSpec/HaveSelector: - Exclude: - - 'spec/features/plate_qc_display_spec.rb' - # Offense count: 21 # This cop supports safe autocorrection (--autocorrect). # Configuration parameters: AllowedMethods, AllowedPatterns. @@ -101,17 +74,10 @@ Lint/DuplicateMethods: - 'lib/accession/accession/tag.rb' - 'lib/label_printer/label_printer/label.rb' -# Offense count: 1 -# This cop supports safe autocorrection (--autocorrect). -Lint/DuplicateRegexpCharacterClassElement: - Exclude: - - 'app/models/barcode/format_handlers.rb' - -# Offense count: 67 +# Offense count: 66 # Configuration parameters: AllowComments, AllowEmptyLambdas. Lint/EmptyBlock: Exclude: - - 'app/api/core/endpoint/basic_handler/actions/inner_action.rb' - 'app/api/endpoints/asset_groups.rb' - 'app/api/endpoints/assets.rb' - 'app/api/endpoints/barcode_printers.rb' @@ -211,12 +177,10 @@ Lint/MissingSuper: - 'lib/label_printer/label_printer/label/sample_manifest_tube.rb' - 'test/unit/tasks/plate_transfer_task_test.rb' -# Offense count: 3 +# Offense count: 1 # Configuration parameters: AllowedMethods, AllowedPatterns. Lint/NestedMethodDefinition: Exclude: - - 'app/api/endpoints/uuids.rb' - - 'app/middleware/api/root_service.rb' - 'lib/eventful_record.rb' # Offense count: 4 @@ -226,10 +190,17 @@ Lint/NonLocalExitFromIterator: - 'app/api/core/io/json/grammar.rb' - 'app/models/create_asset_request.rb' -# Offense count: 1 +# Offense count: 7 # This cop supports safe autocorrection (--autocorrect). Lint/RedundantCopDisableDirective: - Enabled: false + Exclude: + - 'app/controllers/npg_actions/assets_controller.rb' + - 'app/helpers/submissions_helper.rb' + - 'app/heron/factories/event.rb' + - 'app/models/barcode/format_handlers.rb' + - 'app/models/illumina_htp/initial_stock_tube_purpose.rb' + - 'app/models/metadata/form_builder.rb' + - 'lib/tasks/retention_instructions.rake' # Offense count: 4 Lint/ReturnInVoidContext: @@ -284,7 +255,7 @@ Lint/UselessAccessModifier: - 'app/models/product_criteria/basic.rb' # Offense count: 67 -# This cop supports unsafe autocorrection (--autocorrect-all). +# This cop supports safe autocorrection (--autocorrect). # Configuration parameters: AutoCorrect. Lint/UselessAssignment: Exclude: @@ -336,32 +307,40 @@ Lint/UselessAssignment: - 'test/lib/label_printer/plate_creator_test.rb' - 'test/unit/tasks/plate_transfer_task_test.rb' -# Offense count: 4 -# Configuration parameters: AllowedMethods, AllowedPatterns, CountRepeatedAttributes. +# Offense count: 3 +# Configuration parameters: AllowedMethods, AllowedPatterns, CountRepeatedAttributes, Max. Metrics/AbcSize: - Max: 24 + Exclude: + - 'app/controllers/api/v2/transfers/transfers_controller.rb' + - 'app/jobs/export_pool_xp_to_traction_job.rb' + - 'app/sample_manifest_excel/sample_manifest_excel/manifest_type_list.rb' # Offense count: 1 -# Configuration parameters: CountComments, CountAsOne. +# Configuration parameters: CountComments, Max, CountAsOne. Metrics/ClassLength: - Max: 205 + Exclude: + - 'app/middleware/api/endpoint_handler.rb' -# Offense count: 2 -# Configuration parameters: AllowedMethods, AllowedPatterns. +# Offense count: 1 +# Configuration parameters: AllowedMethods, AllowedPatterns, Max. Metrics/CyclomaticComplexity: - Max: 9 + Exclude: + - 'lib/limber/helper.rb' -# Offense count: 2 -# Configuration parameters: CountComments, CountAsOne, AllowedMethods, AllowedPatterns. +# Offense count: 9 +# Configuration parameters: CountComments, Max, CountAsOne, AllowedMethods, AllowedPatterns. Metrics/MethodLength: - Max: 12 - -# Offense count: 1 -# Configuration parameters: AllowedMethods, AllowedPatterns. -Metrics/PerceivedComplexity: - Max: 10 + Exclude: + - 'app/controllers/api/v2/bait_library_layouts_controller.rb' + - 'app/controllers/tag_layout_templates_controller.rb' + - 'app/jobs/export_pool_xp_to_traction_job.rb' + - 'app/models/plate/quad_creator.rb' + - 'app/uat_actions/uat_actions/tube_submission.rb' + - 'app/validators/novaseqx_pe_validator.rb' + - 'lib/record_loader/application_record_loader.rb' + - 'test/unit/import_fluidigm_data_test.rb' -# Offense count: 14 +# Offense count: 13 Naming/AccessorMethodName: Exclude: - 'app/api/core/io/base/json_formatting_behaviour.rb' @@ -371,7 +350,6 @@ Naming/AccessorMethodName: - 'app/models/broadcast_event.rb' - 'app/models/lib_pool_norm_tube_generator.rb' - 'app/models/receptacle.rb' - - 'app/models/specific_tube_creation.rb' - 'app/models/well.rb' - 'lib/authenticated_system.rb' - 'lib/tasks/add_templates_and_printers_to_pmb.rake' @@ -465,7 +443,7 @@ Naming/PredicateName: - 'lib/has_behaviour.rb' - 'lib/manifest_util.rb' -# Offense count: 242 +# Offense count: 243 # Configuration parameters: EnforcedStyle, CheckMethodNames, CheckSymbols, AllowedIdentifiers, AllowedPatterns. # SupportedStyles: snake_case, normalcase, non_integer # AllowedIdentifiers: capture3, iso8601, rfc1123_date, rfc822, rfc2822, rfc3339, x86_64 @@ -592,7 +570,7 @@ RSpec/BeforeAfterAll: - 'spec/sample_manifest_excel/worksheet_spec.rb' - 'spec/sequencescape_excel/worksheet_spec.rb' -# Offense count: 335 +# Offense count: 339 # Configuration parameters: Prefixes, AllowedPatterns. # Prefixes: when, with, without RSpec/ContextWording: @@ -668,18 +646,141 @@ RSpec/ContextWording: # Offense count: 4 # This cop supports unsafe autocorrection (--autocorrect-all). +# Configuration parameters: AutoCorrect. RSpec/EmptyExampleGroup: Exclude: - 'spec/models/illumina_htp/initial_stock_tube_purpose_spec.rb' - 'spec/models/pulldown/requests_spec.rb' - 'spec/models/tag_substitutions_spec.rb' -# Offense count: 345 -# Configuration parameters: CountAsOne. +# Offense count: 390 +# Configuration parameters: Max, CountAsOne. RSpec/ExampleLength: - Max: 21 + Exclude: + - 'spec/api/extraction_attributes_spec.rb' + - 'spec/bulk_submission_excel/configuration_spec.rb' + - 'spec/bulk_submission_excel/data_worksheet_spec.rb' + - 'spec/controllers/npg_actions/assets_controller_spec.rb' + - 'spec/controllers/studies_controller_spec.rb' + - 'spec/controllers/submissions_controller_spec.rb' + - 'spec/lib/accession/accessionable_spec.rb' + - 'spec/lib/accession/request_spec.rb' + - 'spec/lib/accession/sample_spec.rb' + - 'spec/lib/accession/service_spec.rb' + - 'spec/lib/accession/study_spec.rb' + - 'spec/lib/accession/submission_spec.rb' + - 'spec/lib/accession/tag_list_spec.rb' + - 'spec/lib/accession/tag_spec.rb' + - 'spec/lib/add_missing_asset_audit_records_spec.rb' + - 'spec/lib/dev/plate_barcode/cache_barcodes_spec.rb' + - 'spec/lib/lab_where_client_spec.rb' + - 'spec/lib/limber/helper_spec.rb' + - 'spec/lib/mbrave_tags_creator_spec.rb' + - 'spec/lib/populate_numer_of_samples_per_pool_spec.rb' + - 'spec/lib/retention_instructions_spec.rb' + - 'spec/models/aliquot_spec.rb' + - 'spec/models/bait_library_type_spec.rb' + - 'spec/models/barcode_printer_spec.rb' + - 'spec/models/batch_spec.rb' + - 'spec/models/broadcast_event/broadcast_event_spec.rb' + - 'spec/models/bulk_submission_spec.rb' + - 'spec/models/labware_spec.rb' + - 'spec/models/labwhere_reception_spec.rb' + - 'spec/models/lane_spec.rb' + - 'spec/models/linear_submission_spec.rb' + - 'spec/models/location_report_form_spec.rb' + - 'spec/models/map_spec.rb' + - 'spec/models/orders/order_spec.rb' + - 'spec/models/parsers/pbmc_count_parser_spec.rb' + - 'spec/models/plate/quad_creator_spec.rb' + - 'spec/models/plate_volume_spec.rb' + - 'spec/models/pooling_spec.rb' + - 'spec/models/primer_panel_spec.rb' + - 'spec/models/qc_report_spec.rb' + - 'spec/models/qc_result/qc_result_factory_spec.rb' + - 'spec/models/qc_result/qc_result_spec.rb' + - 'spec/models/qcable_creator_spec.rb' + - 'spec/models/request/sample_compound_aliquot_transfer_spec.rb' + - 'spec/models/request/statistics/counter_spec.rb' + - 'spec/models/request_spec.rb' + - 'spec/models/sample_manifest/generator_spec.rb' + - 'spec/models/sample_manifest/uploader_spec.rb' + - 'spec/models/sample_manifest_spec.rb' + - 'spec/models/sample_spec.rb' + - 'spec/models/state_changer/mx_tube_spec.rb' + - 'spec/models/stock_stamper_spec.rb' + - 'spec/models/study_spec.rb' + - 'spec/models/submission/submission_creator_spec.rb' + - 'spec/models/submission_spec.rb' + - 'spec/models/tag_layout_template_spec.rb' + - 'spec/models/tag_substitutions_spec.rb' + - 'spec/models/transfer/between_plates_spec.rb' + - 'spec/models/tube_rack_spec.rb' + - 'spec/models/user_query_spec.rb' + - 'spec/models/user_spec.rb' + - 'spec/models/well_attribute_spec.rb' + - 'spec/models/well_spec.rb' + - 'spec/models/work_completion_spec.rb' + - 'spec/models/work_order_spec.rb' + - 'spec/requests/api/v2/barcode_printers_spec.rb' + - 'spec/requests/api/v2/custom_metadatum_collections_spec.rb' + - 'spec/requests/api/v2/heron/tube_racks_spec.rb' + - 'spec/requests/api/v2/labware_spec.rb' + - 'spec/requests/api/v2/plate_purposes_spec.rb' + - 'spec/requests/api/v2/plates_spec.rb' + - 'spec/requests/api/v2/qc_assays_spec.rb' + - 'spec/requests/api/v2/qc_results_spec.rb' + - 'spec/requests/api/v2/sample_metadata_spec.rb' + - 'spec/requests/api/v2/shared_examples/api_key_authenticatable.rb' + - 'spec/requests/api/v2/tag_layout_templates_spec.rb' + - 'spec/requests/api/v2/tag_layouts_spec.rb' + - 'spec/requests/api/v2/transfers/transfers_spec.rb' + - 'spec/requests/api/v2/tube_purposes_spec.rb' + - 'spec/requests/api/v2/users_spec.rb' + - 'spec/requests/api/v2/volume_update_spec.rb' + - 'spec/requests/api/v2/wells_spec.rb' + - 'spec/requests/users_request_spec.rb' + - 'spec/resources/api/v2/aliquot_resource_spec.rb' + - 'spec/resources/api/v2/lot_resource_spec.rb' + - 'spec/resources/api/v2/lot_type_resource_spec.rb' + - 'spec/resources/api/v2/pick_list_resource_spec.rb' + - 'spec/resources/api/v2/plate_purpose_resource_spec.rb' + - 'spec/resources/api/v2/purpose_resource_spec.rb' + - 'spec/resources/api/v2/qcable_resource_spec.rb' + - 'spec/resources/api/v2/receptacle_resource_spec.rb' + - 'spec/resources/api/v2/request_resource_spec.rb' + - 'spec/resources/api/v2/request_type_resource_spec.rb' + - 'spec/resources/api/v2/sample_metadata_resource_spec.rb' + - 'spec/resources/api/v2/submission_resource_spec.rb' + - 'spec/resources/api/v2/tag_group_resource_spec.rb' + - 'spec/resources/api/v2/transfers/transfer_resource_spec.rb' + - 'spec/resources/api/v2/tube_rack_resource_spec.rb' + - 'spec/resources/api/v2/tube_resource_spec.rb' + - 'spec/sample_manifest_excel/configuration_spec.rb' + - 'spec/sample_manifest_excel/download_spec.rb' + - 'spec/sample_manifest_excel/manifest_type_list_spec.rb' + - 'spec/sample_manifest_excel/tags_spec.rb' + - 'spec/sample_manifest_excel/upload/data_spec.rb' + - 'spec/sample_manifest_excel/upload/processor_spec.rb' + - 'spec/sample_manifest_excel/upload/row_spec.rb' + - 'spec/sample_manifest_excel/upload/upload_spec.rb' + - 'spec/sample_manifest_excel/worksheet_spec.rb' + - 'spec/sequencescape_excel/column_list_spec.rb' + - 'spec/sequencescape_excel/column_spec.rb' + - 'spec/sequencescape_excel/conditional_formatting_list_spec.rb' + - 'spec/sequencescape_excel/configuration_spec.rb' + - 'spec/sequencescape_excel/formula_spec.rb' + - 'spec/sequencescape_excel/list_spec.rb' + - 'spec/sequencescape_excel/range_list_spec.rb' + - 'spec/sequencescape_excel/specialised_field_spec.rb' + - 'spec/sequencescape_excel/validation_spec.rb' + - 'spec/tasks/support/disable_hiseq_submission_templates_spec.rb' + - 'spec/tasks/support/remove_duplicate_asset_links_spec.rb' + - 'spec/views/labware/show_chromium_chip_spec.rb' + - 'spec/views/samples/index_html_erb_spec.rb' + - 'spec/views/samples/show_html_erb_spec.rb' -# Offense count: 274 +# Offense count: 272 # This cop supports safe autocorrection (--autocorrect). # Configuration parameters: CustomTransform, IgnoredWords, DisallowedExamples. # DisallowedExamples: works @@ -691,7 +792,6 @@ RSpec/ExampleWording: - 'spec/heron/factories/sample_spec.rb' - 'spec/heron/factories/tube_rack_spec.rb' - 'spec/lib/accession/study_spec.rb' - - 'spec/models/parsers/cardinal_pbmc_count_parser_spec.rb' - 'spec/models/plate/quad_creator_spec.rb' - 'spec/models/qc_result/qc_result_factory_spec.rb' - 'spec/models/qcable_creator_spec.rb' @@ -711,38 +811,6 @@ RSpec/ExampleWording: - 'spec/sequencescape_excel/validation_spec.rb' - 'spec/sequencescape_excel/worksheet_spec.rb' -# Offense count: 1 -# This cop supports safe autocorrection (--autocorrect). -RSpec/ExpectActual: - Exclude: - - 'spec/models/qc_report_spec.rb' - -# Offense count: 12 -# Configuration parameters: Include, CustomTransform, IgnoreMethods, SpecSuffixOnly. -# Include: **/*_spec*rb*, **/spec/**/* -RSpec/FilePath: - Exclude: - - 'spec/bulk_submission_excel/data_worksheet_spec.rb' - - 'spec/lib/accession/configuration_spec.rb' - - 'spec/lib/label_printer/sample_manifest_plate_double_spec.rb' - - 'spec/models/location_report_form_spec.rb' - - 'spec/models/std_library_request_spec.rb' - - 'spec/models/tag_group_form_object_spec.rb' - - 'spec/models/tube_purpose_spec.rb' - - 'spec/requests/api/v2/qc_assays_spec.rb' - - 'spec/requests/api/v2/qc_results_spec.rb' - - 'spec/resources/api/v2/project_resource_spec.rb' - - 'spec/sample_manifest_excel/upload/upload_spec.rb' - - 'spec/sequencescape_excel/configuration_spec.rb' - -# Offense count: 1 -# This cop supports safe autocorrection (--autocorrect). -# Configuration parameters: EnforcedStyle. -# SupportedStyles: implicit, each, example -RSpec/HookArgument: - Exclude: - - 'spec/spec_helper.rb' - # Offense count: 248 # Configuration parameters: AssignmentOnly. RSpec/InstanceVariable: @@ -785,7 +853,7 @@ RSpec/LeakyConstantDeclaration: - 'spec/sample_manifest_excel/tags_spec.rb' - 'spec/sequencescape_excel/list_spec.rb' -# Offense count: 39 +# Offense count: 40 RSpec/LetSetup: Exclude: - 'spec/controllers/searches_controller_spec.rb' @@ -831,27 +899,419 @@ RSpec/MessageSpies: - 'spec/models/qc_result/qc_result_spec.rb' - 'spec/models/tasks/plate_template_task_spec.rb' - 'spec/sample_manifest_excel/upload/upload_spec.rb' - - 'spec/sequencescape_excel/validation_spec.rb' - - 'spec/tasks/create_mbrave_tags_spec.rb' + - 'spec/sequencescape_excel/validation_spec.rb' + - 'spec/tasks/create_mbrave_tags_spec.rb' + - 'spec/uat_actions/test_submission_spec.rb' + +# Offense count: 2 +RSpec/MissingExpectationTargetMethod: + Exclude: + - 'spec/models/robot/generator/beckman_spec.rb' + - 'spec/models/robot/generator/hamilton_spec.rb' + +# Offense count: 3 +RSpec/MultipleDescribes: + Exclude: + - 'spec/api/plate_purpose_spec.rb' + - 'spec/lib/label_printer/asset_labels_spec.rb' + - 'spec/models/qc_result/qc_result_spec.rb' + +# Offense count: 948 +# Configuration parameters: Max. +RSpec/MultipleExpectations: + Exclude: + - 'spec/api/api_root_spec.rb' + - 'spec/api/asset_audit_spec.rb' + - 'spec/api/dilution_plate_purpose_spec.rb' + - 'spec/api/extraction_attributes_spec.rb' + - 'spec/api/labware_spec.rb' + - 'spec/api/multiplexed_library_tube_spec.rb' + - 'spec/api/plate_purpose_spec.rb' + - 'spec/api/plate_spec.rb' + - 'spec/api/qcable_creator_spec.rb' + - 'spec/api/receptacle_spec.rb' + - 'spec/api/request_types_spec.rb' + - 'spec/api/shared_examples.rb' + - 'spec/api/specific_tube_creation_spec.rb' + - 'spec/api/tag_layout_template_spec.rb' + - 'spec/api/transfer_request_collection_spec.rb' + - 'spec/api/tube_creation_spec.rb' + - 'spec/api/tube_purpose_spec.rb' + - 'spec/api/well_spec.rb' + - 'spec/api/work_completion_spec.rb' + - 'spec/bulk_submission_excel/configuration_spec.rb' + - 'spec/bulk_submission_excel/data_worksheet_spec.rb' + - 'spec/bulk_submission_excel/download_spec.rb' + - 'spec/controllers/admin/abilities_controller_spec.rb' + - 'spec/controllers/api/v2/heron/plates_controller_spec.rb' + - 'spec/controllers/api/v2/heron/tube_racks_controller_spec.rb' + - 'spec/controllers/bulk_submission_excel/downloads_controller_spec.rb' + - 'spec/controllers/driver_files_controller_spec.rb' + - 'spec/controllers/labwhere_receptions_controller_spec.rb' + - 'spec/controllers/npg_actions/assets_controller_spec.rb' + - 'spec/controllers/receptacles_controller_spec.rb' + - 'spec/controllers/report_fails_controller_spec.rb' + - 'spec/controllers/robot_verifications_controller_spec.rb' + - 'spec/controllers/studies_controller_spec.rb' + - 'spec/controllers/submissions_controller_spec.rb' + - 'spec/controllers/tag_sets_controller_spec.rb' + - 'spec/helpers/compound_sample_helper_spec.rb' + - 'spec/heron/factories/concerns/contents_spec.rb' + - 'spec/heron/factories/plate_spec.rb' + - 'spec/heron/factories/sample_spec.rb' + - 'spec/heron/factories/tube_spec.rb' + - 'spec/jobs/export_pool_xp_to_traction_job_spec.rb' + - 'spec/lib/accession/accessionable_spec.rb' + - 'spec/lib/accession/configuration_spec.rb' + - 'spec/lib/accession/contact_spec.rb' + - 'spec/lib/accession/request_spec.rb' + - 'spec/lib/accession/response_spec.rb' + - 'spec/lib/accession/sample_spec.rb' + - 'spec/lib/accession/service_spec.rb' + - 'spec/lib/accession/study_spec.rb' + - 'spec/lib/accession/submission_spec.rb' + - 'spec/lib/accession/tag_list_spec.rb' + - 'spec/lib/accession/tag_spec.rb' + - 'spec/lib/add_missing_asset_audit_records_spec.rb' + - 'spec/lib/dev/plate_barcode/cache_barcodes_spec.rb' + - 'spec/lib/lab_where_client_spec.rb' + - 'spec/lib/limber/helper_spec.rb' + - 'spec/lib/mbrave_tags_creator_spec.rb' + - 'spec/lib/migration_extensions/encoding_changes_spec.rb' + - 'spec/lib/record_loader/flowcell_type_request_type_loader_spec.rb' + - 'spec/lib/record_loader/pipeline_loader_spec.rb' + - 'spec/lib/record_loader/pipeline_request_information_type_loader_spec.rb' + - 'spec/lib/record_loader/plate_purpose_loader_spec.rb' + - 'spec/lib/record_loader/product_catalogue_loader_spec.rb' + - 'spec/lib/record_loader/submission_template_loader_spec.rb' + - 'spec/lib/record_loader/tag_set_loader_spec.rb' + - 'spec/lib/retention_instructions_spec.rb' + - 'spec/mailers/user_query_mailer_spec.rb' + - 'spec/models/aliquot_spec.rb' + - 'spec/models/bait_library_type_spec.rb' + - 'spec/models/barcode_printer_spec.rb' + - 'spec/models/barcode_spec.rb' + - 'spec/models/batch_spec.rb' + - 'spec/models/broadcast_event/broadcast_event_spec.rb' + - 'spec/models/broadcast_event/helpers/external_subjects_spec.rb' + - 'spec/models/broadcast_event/library_complete_spec.rb' + - 'spec/models/broadcast_event/plate_cherrypicked_spec.rb' + - 'spec/models/broadcast_event/pool_released_spec.rb' + - 'spec/models/broadcast_event/qc_assay_spec.rb' + - 'spec/models/broadcast_event/sequencing_complete_spec.rb' + - 'spec/models/bulk_submission_spec.rb' + - 'spec/models/cherrypick_request_spec.rb' + - 'spec/models/cherrypick_task/control_locator_spec.rb' + - 'spec/models/comment_spec.rb' + - 'spec/models/illumina_htp/requests/gbs_request_spec.rb' + - 'spec/models/illumina_htp/requests/heron_request_spec.rb' + - 'spec/models/illumina_htp/requests/heron_tailed_request_spec.rb' + - 'spec/models/lab_event_spec.rb' + - 'spec/models/labwhere_reception_spec.rb' + - 'spec/models/lane_spec.rb' + - 'spec/models/linear_submission_spec.rb' + - 'spec/models/location_report_spec.rb' + - 'spec/models/lot_type_spec.rb' + - 'spec/models/map_spec.rb' + - 'spec/models/orders/order_spec.rb' + - 'spec/models/parsers/pbmc_count_parser_spec.rb' + - 'spec/models/phi_x/spiked_buffer_spec.rb' + - 'spec/models/phi_x/stock_spec.rb' + - 'spec/models/plate/quad_creator_spec.rb' + - 'spec/models/plate_barcode_spec.rb' + - 'spec/models/plate_spec.rb' + - 'spec/models/plate_type_spec.rb' + - 'spec/models/plate_volume_spec.rb' + - 'spec/models/poly_metadatum_spec.rb' + - 'spec/models/pooling_spec.rb' + - 'spec/models/primer_panel_spec.rb' + - 'spec/models/qc_report_spec.rb' + - 'spec/models/qc_result/qc_result_factory_spec.rb' + - 'spec/models/qc_result/qc_result_spec.rb' + - 'spec/models/qcable_creator_spec.rb' + - 'spec/models/racked_tube_spec.rb' + - 'spec/models/report_fail_spec.rb' + - 'spec/models/request/sample_compound_aliquot_transfer_spec.rb' + - 'spec/models/request/traction/grid_ion_spec.rb' + - 'spec/models/request_event_spec.rb' + - 'spec/models/request_spec.rb' + - 'spec/models/robot/pick_data_spec.rb' + - 'spec/models/sample_manifest/generator_spec.rb' + - 'spec/models/sample_manifest/uploader_spec.rb' + - 'spec/models/sample_manifest_spec.rb' + - 'spec/models/sample_spec.rb' + - 'spec/models/sequencing_request_spec.rb' + - 'spec/models/state_changer/mx_tube_spec.rb' + - 'spec/models/state_changer/qcable_library_plate_spec.rb' + - 'spec/models/stock_stamper_spec.rb' + - 'spec/models/study_spec.rb' + - 'spec/models/submission/submission_creator_spec.rb' + - 'spec/models/submission_spec.rb' + - 'spec/models/tag2_layout_spec.rb' + - 'spec/models/tag2_layout_template_spec.rb' + - 'spec/models/tag_layout_template_spec.rb' + - 'spec/models/tag_set_spec.rb' + - 'spec/models/tag_substitutions_spec.rb' + - 'spec/models/transfer/between_plates_spec.rb' + - 'spec/models/transfer_request_spec.rb' + - 'spec/models/tube_rack_spec.rb' + - 'spec/models/tube_spec.rb' + - 'spec/models/user_query_spec.rb' + - 'spec/models/user_spec.rb' + - 'spec/models/well_attribute_spec.rb' + - 'spec/models/well_spec.rb' + - 'spec/models/work_completion_spec.rb' + - 'spec/models/work_order_spec.rb' + - 'spec/requests/api/v2/aliquots_spec.rb' + - 'spec/requests/api/v2/asset_audits_spec.rb' + - 'spec/requests/api/v2/bait_library_layouts_spec.rb' + - 'spec/requests/api/v2/barcode_printers_spec.rb' + - 'spec/requests/api/v2/comments_spec.rb' + - 'spec/requests/api/v2/custom_metadatum_collections_spec.rb' + - 'spec/requests/api/v2/heron/plates_spec.rb' + - 'spec/requests/api/v2/labware_spec.rb' + - 'spec/requests/api/v2/lanes_spec.rb' + - 'spec/requests/api/v2/lot_types_spec.rb' + - 'spec/requests/api/v2/lots_spec.rb' + - 'spec/requests/api/v2/orders_spec.rb' + - 'spec/requests/api/v2/pick_lists_spec.rb' + - 'spec/requests/api/v2/plate_purposes_spec.rb' + - 'spec/requests/api/v2/plate_templates_spec.rb' + - 'spec/requests/api/v2/plates_spec.rb' + - 'spec/requests/api/v2/poly_metadata_spec.rb' + - 'spec/requests/api/v2/pooled_plate_creations_spec.rb' + - 'spec/requests/api/v2/pre_capture_pools_spec.rb' + - 'spec/requests/api/v2/primer_panels_spec.rb' + - 'spec/requests/api/v2/purposes_spec.rb' + - 'spec/requests/api/v2/qc_assays_spec.rb' + - 'spec/requests/api/v2/qc_results_spec.rb' + - 'spec/requests/api/v2/qcables_spec.rb' + - 'spec/requests/api/v2/receptacles_spec.rb' + - 'spec/requests/api/v2/request_types_spec.rb' + - 'spec/requests/api/v2/requests_spec.rb' + - 'spec/requests/api/v2/sample_metadata_spec.rb' + - 'spec/requests/api/v2/shared_examples/api_key_authenticatable.rb' + - 'spec/requests/api/v2/specific_tube_creations_spec.rb' + - 'spec/requests/api/v2/state_changes_spec.rb' + - 'spec/requests/api/v2/studies_spec.rb' + - 'spec/requests/api/v2/submission_templates_spec.rb' + - 'spec/requests/api/v2/submissions_spec.rb' + - 'spec/requests/api/v2/tag_groups_spec.rb' + - 'spec/requests/api/v2/tag_layout_templates_spec.rb' + - 'spec/requests/api/v2/tag_layouts_spec.rb' + - 'spec/requests/api/v2/transfer_requests_spec.rb' + - 'spec/requests/api/v2/transfer_templates_spec.rb' + - 'spec/requests/api/v2/transfers/transfers_spec.rb' + - 'spec/requests/api/v2/tube_purposes_spec.rb' + - 'spec/requests/api/v2/tube_racks_spec.rb' + - 'spec/requests/api/v2/tubes_spec.rb' + - 'spec/requests/api/v2/users_spec.rb' + - 'spec/requests/api/v2/volume_update_spec.rb' + - 'spec/requests/api/v2/wells_spec.rb' + - 'spec/requests/api/v2/work_orders_spec.rb' + - 'spec/requests/qc_files_spec.rb' + - 'spec/resources/api/v2/plate_purpose_resource_spec.rb' + - 'spec/resources/api/v2/tube_rack_resource_spec.rb' + - 'spec/sample_manifest_excel/configuration_spec.rb' + - 'spec/sample_manifest_excel/download_spec.rb' + - 'spec/sample_manifest_excel/manifest_type_list_spec.rb' + - 'spec/sample_manifest_excel/sample_manifest_excel_spec.rb' + - 'spec/sample_manifest_excel/tags_spec.rb' + - 'spec/sample_manifest_excel/upload/data_spec.rb' + - 'spec/sample_manifest_excel/upload/processor_spec.rb' + - 'spec/sample_manifest_excel/upload/row_spec.rb' + - 'spec/sample_manifest_excel/upload/upload_spec.rb' + - 'spec/sample_manifest_excel/worksheet_spec.rb' + - 'spec/sequencescape_excel/cell_spec.rb' + - 'spec/sequencescape_excel/column_list_spec.rb' + - 'spec/sequencescape_excel/column_spec.rb' + - 'spec/sequencescape_excel/conditional_formatting_default_list_spec.rb' + - 'spec/sequencescape_excel/conditional_formatting_default_spec.rb' + - 'spec/sequencescape_excel/conditional_formatting_list_spec.rb' + - 'spec/sequencescape_excel/conditional_formatting_spec.rb' + - 'spec/sequencescape_excel/configuration_spec.rb' + - 'spec/sequencescape_excel/formula_spec.rb' + - 'spec/sequencescape_excel/list_spec.rb' + - 'spec/sequencescape_excel/range_list_spec.rb' + - 'spec/sequencescape_excel/range_spec.rb' + - 'spec/sequencescape_excel/specialised_field_spec.rb' + - 'spec/sequencescape_excel/validation_spec.rb' + - 'spec/sequencescape_excel/worksheet_spec.rb' + - 'spec/tasks/support/add_stock_rna_plate_to_working_dilution_parents_spec.rb' + - 'spec/tasks/support/disable_hiseq_submission_templates_spec.rb' + - 'spec/tasks/support/remove_duplicate_asset_links_spec.rb' + - 'spec/uat_actions/generate_plate_concentrations_spec.rb' + - 'spec/uat_actions/generate_plates_spec.rb' + - 'spec/uat_actions/generate_primer_panel_spec.rb' + - 'spec/uat_actions/generate_qc_results_spec.rb' + - 'spec/uat_actions/generate_sample_manifest_spec.rb' + - 'spec/uat_actions/generate_spiked_buffer_tube_spec.rb' + - 'spec/uat_actions/generate_tag_group_spec.rb' + - 'spec/uat_actions/generate_tag_layout_template_spec.rb' + - 'spec/uat_actions/generate_tagged_plates_spec.rb' + - 'spec/uat_actions/generate_tube_racks_spec.rb' + - 'spec/uat_actions/generate_tubes_spec.rb' + - 'spec/uat_actions/integration_suite_tools_spec.rb' + - 'spec/uat_actions/plate_information_spec.rb' + - 'spec/uat_actions/test_submission_spec.rb' + - 'spec/uat_actions/tube_submission_spec.rb' + - 'spec/uat_actions/uat_actions_spec.rb' + - 'spec/views/labware/retention_instruction_spec.rb' + - 'spec/views/labware/show_chromium_chip_spec.rb' + - 'spec/views/samples/index_html_erb_spec.rb' + +# Offense count: 1115 +# Configuration parameters: AllowSubject, Max. +RSpec/MultipleMemoizedHelpers: + Exclude: + - 'spec/api/extraction_attributes_spec.rb' + - 'spec/api/labware_spec.rb' + - 'spec/api/multiplexed_library_tube_spec.rb' + - 'spec/api/plate_spec.rb' + - 'spec/api/qcable_creator_spec.rb' + - 'spec/api/receptacle_spec.rb' + - 'spec/api/specific_tube_creation_spec.rb' + - 'spec/api/state_change_spec.rb' + - 'spec/api/submission_pool_spec.rb' + - 'spec/api/tag_layout_template_spec.rb' + - 'spec/api/transfer_request_collection_spec.rb' + - 'spec/api/tube_creation_spec.rb' + - 'spec/api/well_spec.rb' + - 'spec/api/work_completion_spec.rb' + - 'spec/bulk_submission_excel/data_worksheet_spec.rb' + - 'spec/bulk_submission_excel/download_spec.rb' + - 'spec/controllers/api/v2/bioscan/export_pool_xp_to_traction_controller_spec.rb' + - 'spec/controllers/api/v2/heron/plates_controller_spec.rb' + - 'spec/controllers/api/v2/heron/tube_racks_controller_spec.rb' + - 'spec/controllers/driver_files_controller_spec.rb' + - 'spec/controllers/npg_actions/assets_controller_spec.rb' + - 'spec/controllers/receptacles_controller_spec.rb' + - 'spec/controllers/robot_verifications_controller_spec.rb' + - 'spec/controllers/searches_controller_spec.rb' + - 'spec/controllers/studies/information_controller_spec.rb' + - 'spec/controllers/studies_controller_spec.rb' + - 'spec/features/assets/asset_submission_spec.rb' + - 'spec/features/creating_a_quad_stamp_spec.rb' + - 'spec/features/generate_a_bulk_submission_template_spec.rb' + - 'spec/features/gpl207_bug_incorrect_submission_id_on_transfer_spec.rb' + - 'spec/features/location_reports/location_reports_spec.rb' + - 'spec/features/patient_consent_withdrawl_spec.rb' + - 'spec/features/perform_a_tag_substitution_spec.rb' + - 'spec/features/pipelines/cherrypick/cherrypick_for_fluidigm_pipeline_micro_litre_spec.rb' + - 'spec/features/pipelines/cherrypick/cherrypick_pipeline_spec.rb' + - 'spec/features/pipelines/creating_an_empty_batch_spec.rb' + - 'spec/features/pipelines/sequencing/following_a_sequencing_pipeline_spec.rb' + - 'spec/features/pipelines/sequencing/following_a_sequencing_pipeline_with_compound_sample_creation_spec.rb' + - 'spec/features/pipelines/viewing_request_comments_spec.rb' + - 'spec/features/pooling_spec.rb' + - 'spec/features/retrospective_failure_spec.rb' + - 'spec/features/sample_manifests/create_manifest_spec.rb' + - 'spec/features/starting_transfers_on_repools_starts_repools_spec.rb' + - 'spec/features/studies/view_study_request_links_spec.rb' + - 'spec/features/submissions/bulk_submissions_spec.rb' + - 'spec/helpers/batches_helper_spec.rb' + - 'spec/heron/factories/concerns/contents_spec.rb' + - 'spec/heron/factories/plate_spec.rb' + - 'spec/insdc/import_countries_spec.rb' + - 'spec/jobs/export_pool_xp_to_traction_job_spec.rb' + - 'spec/lib/label_printer/batch_plate_spec.rb' + - 'spec/lib/label_printer/swipecard_spec.rb' + - 'spec/lib/record_loader/submission_template_loader_spec.rb' + - 'spec/models/ability_spec.rb' + - 'spec/models/aliquot_spec.rb' + - 'spec/models/api/aliquot_io_spec.rb' + - 'spec/models/api/messages/flowcell_io_spec.rb' + - 'spec/models/api/messages/pac_bio_run_io_spec.rb' + - 'spec/models/api/messages/pac_bio_run_with_tag2_io_spec.rb' + - 'spec/models/api/messages/well_stock_resource_io_spec.rb' + - 'spec/models/barcode_spec.rb' + - 'spec/models/broadcast_event/broadcast_event_spec.rb' + - 'spec/models/broadcast_event/helpers/external_subjects_spec.rb' + - 'spec/models/broadcast_event/lab_event_spec.rb' + - 'spec/models/broadcast_event/plate_cherrypicked_spec.rb' + - 'spec/models/broadcast_event/pool_released_spec.rb' + - 'spec/models/broadcast_event/qc_assay_spec.rb' + - 'spec/models/broadcast_event/sequencing_complete_spec.rb' + - 'spec/models/bulk_submission_spec.rb' + - 'spec/models/comment_spec.rb' + - 'spec/models/external_release_event_spec.rb' + - 'spec/models/illumina_htp/initial_stock_tube_purpose_spec.rb' + - 'spec/models/labware_spec.rb' + - 'spec/models/linear_submission_spec.rb' + - 'spec/models/location_report_form_spec.rb' + - 'spec/models/orders/order_spec.rb' + - 'spec/models/plate/quad_creator_spec.rb' + - 'spec/models/plate_barcode_spec.rb' + - 'spec/models/pooling_spec.rb' + - 'spec/models/qc_result/qc_result_factory_spec.rb' + - 'spec/models/receptacle/downstream_aliquots_removal_spec.rb' + - 'spec/models/receptacle_spec.rb' + - 'spec/models/request/sample_compound_aliquot_transfer_spec.rb' + - 'spec/models/request/traction/grid_ion_spec.rb' + - 'spec/models/request_information_type_spec.rb' + - 'spec/models/request_spec.rb' + - 'spec/models/robot/pick_data_spec.rb' + - 'spec/models/robot/verification/source_dest_beds_spec.rb' + - 'spec/models/robot/verification/source_dest_control_beds_spec.rb' + - 'spec/models/sample_manifest/generator_spec.rb' + - 'spec/models/sample_manifest_spec.rb' + - 'spec/models/sequencing_request_spec.rb' + - 'spec/models/specific_tube_creations_spec.rb' + - 'spec/models/state_changer/initial_stock_tube_spec.rb' + - 'spec/models/state_changer/mx_tube_spec.rb' + - 'spec/models/state_changer/qcable_library_plate_spec.rb' + - 'spec/models/state_changer/standard_plate_spec.rb' + - 'spec/models/state_changer/stock_tube_spec.rb' + - 'spec/models/std_library_request_spec.rb' + - 'spec/models/study_spec.rb' + - 'spec/models/submission_spec.rb' + - 'spec/models/tag_layout_spec.rb' + - 'spec/models/tag_layout_template_spec.rb' + - 'spec/models/tag_set_spec.rb' + - 'spec/models/tag_substitutions_spec.rb' + - 'spec/models/tasks/cherrypick_task_spec.rb' + - 'spec/models/tasks/plate_template_task_spec.rb' + - 'spec/models/tasks/set_descriptors_handler/handler_spec.rb' + - 'spec/models/transfer_request_collection_spec.rb' + - 'spec/models/transfer_request_spec.rb' + - 'spec/models/tube_rack_spec.rb' + - 'spec/models/work_completion_spec.rb' + - 'spec/requests/api/v2/bait_library_layouts_spec.rb' + - 'spec/requests/api/v2/custom_metadatum_collections_spec.rb' + - 'spec/requests/api/v2/heron/plates_spec.rb' + - 'spec/requests/api/v2/heron/tube_racks_spec.rb' + - 'spec/requests/api/v2/plates_spec.rb' + - 'spec/requests/api/v2/pooled_plate_creations_spec.rb' + - 'spec/requests/api/v2/receptacles_spec.rb' + - 'spec/requests/api/v2/specific_tube_creations_spec.rb' + - 'spec/requests/api/v2/state_changes_spec.rb' + - 'spec/requests/api/v2/tag_layouts_spec.rb' + - 'spec/requests/api/v2/transfers/transfers_spec.rb' + - 'spec/requests/api/v2/wells_spec.rb' + - 'spec/requests/plate_picks_request_spec.rb' + - 'spec/resources/api/v2/plate_purpose_resource_spec.rb' + - 'spec/sample_manifest_excel/upload/processor_spec.rb' + - 'spec/sample_manifest_excel/upload/row_spec.rb' + - 'spec/sample_manifest_excel/upload/upload_spec.rb' + - 'spec/sample_manifest_excel/worksheet_spec.rb' + - 'spec/sequencescape_excel/column_spec.rb' + - 'spec/sequencescape_excel/specialised_field_spec.rb' + - 'spec/shared_contexts/limber_shared_context.rb' + - 'spec/tasks/support/add_stock_rna_plate_to_working_dilution_parents_spec.rb' + - 'spec/tasks/support/remove_duplicate_asset_links_spec.rb' + - 'spec/uat_actions/generate_plates_spec.rb' + - 'spec/uat_actions/generate_sample_manifest_spec.rb' + - 'spec/uat_actions/generate_tag_layout_template_spec.rb' + - 'spec/uat_actions/generate_tagged_plates_spec.rb' + - 'spec/uat_actions/plate_information_spec.rb' - 'spec/uat_actions/test_submission_spec.rb' + - 'spec/uat_actions/tube_submission_spec.rb' + - 'spec/uat_actions/uat_actions_spec.rb' + - 'spec/views/labware/show_chromium_chip_spec.rb' + - 'spec/views/labware/show_html_erb_spec.rb' + - 'spec/views/tube_rack_summaries/show_html_erb_spec.rb' -# Offense count: 3 -RSpec/MultipleDescribes: - Exclude: - - 'spec/api/plate_purpose_spec.rb' - - 'spec/lib/label_printer/asset_labels_spec.rb' - - 'spec/models/qc_result/qc_result_spec.rb' - -# Offense count: 815 -RSpec/MultipleExpectations: - Max: 18 - -# Offense count: 959 -# Configuration parameters: AllowSubject. -RSpec/MultipleMemoizedHelpers: - Max: 46 - -# Offense count: 388 +# Offense count: 376 # Configuration parameters: EnforcedStyle, IgnoreSharedExamples. # SupportedStyles: always, named_only RSpec/NamedSubject: @@ -917,21 +1377,87 @@ RSpec/NamedSubject: - 'spec/resources/api/v2/submission_resource_spec.rb' - 'spec/resources/api/v2/tag_group_resource_spec.rb' - 'spec/resources/api/v2/tube_resource_spec.rb' - - 'spec/resources/api/v2/user_resource_spec.rb' -# Offense count: 391 -# Configuration parameters: AllowedGroups. +# Offense count: 523 +# Configuration parameters: Max, AllowedGroups. RSpec/NestedGroups: - Max: 6 - -# Offense count: 10 -# This cop supports safe autocorrection (--autocorrect). -RSpec/Rails/MinitestAssertions: Exclude: - - 'spec/models/robot/generator/beckman_spec.rb' - - 'spec/models/robot/generator/hamilton_spec.rb' - - 'spec/models/robot/generator/tecan_spec.rb' + - 'spec/api/extraction_attributes_spec.rb' + - 'spec/api/specific_tube_creation_spec.rb' + - 'spec/api/tube_creation_spec.rb' + - 'spec/controllers/bulk_submission_excel/downloads_controller_spec.rb' + - 'spec/controllers/lab_searches_controller_spec.rb' + - 'spec/controllers/labwhere_receptions_controller_spec.rb' + - 'spec/controllers/report_fails_controller_spec.rb' + - 'spec/controllers/robot_verifications_controller_spec.rb' + - 'spec/controllers/samples_controller_spec.rb' + - 'spec/controllers/searches_controller_spec.rb' + - 'spec/controllers/studies_controller_spec.rb' + - 'spec/controllers/submissions_controller_spec.rb' + - 'spec/features/gpl207_bug_incorrect_submission_id_on_transfer_spec.rb' + - 'spec/features/sample_manifests/uploader_for_manifests_with_tag_sequences_spec.rb' + - 'spec/features/submissions/bulk_submissions_spec.rb' + - 'spec/helpers/assets_helper_spec.rb' + - 'spec/heron/factories/concerns/contents_spec.rb' + - 'spec/heron/factories/plate_spec.rb' + - 'spec/heron/factories/sample_spec.rb' + - 'spec/models/api/messages/flowcell_io_spec.rb' + - 'spec/models/broadcast_event/broadcast_event_spec.rb' + - 'spec/models/broadcast_event/plate_cherrypicked_spec.rb' + - 'spec/models/illumina_htp/initial_stock_tube_purpose_spec.rb' + - 'spec/models/labware_spec.rb' + - 'spec/models/linear_submission_spec.rb' + - 'spec/models/location_report_form_spec.rb' + - 'spec/models/location_report_spec.rb' + - 'spec/models/map_spec.rb' + - 'spec/models/orders/order_spec.rb' + - 'spec/models/phi_x/spiked_buffer_spec.rb' + - 'spec/models/phi_x/stock_spec.rb' + - 'spec/models/plate/quad_creator_spec.rb' + - 'spec/models/plate_purpose/additional_input_spec.rb' + - 'spec/models/plate_spec.rb' + - 'spec/models/qc_result/qc_result_factory_spec.rb' + - 'spec/models/receptacle_spec.rb' + - 'spec/models/request/sample_compound_aliquot_transfer_spec.rb' + - 'spec/models/request_spec.rb' + - 'spec/models/request_type_spec.rb' + - 'spec/models/robot/pick_data_spec.rb' + - 'spec/models/sample_manifest_spec.rb' + - 'spec/models/sequencing_request_spec.rb' + - 'spec/models/state_changer/mx_tube_spec.rb' + - 'spec/models/state_changer/standard_plate_spec.rb' + - 'spec/models/std_library_request_spec.rb' + - 'spec/models/study_spec.rb' + - 'spec/models/tag_group/adapter_type_spec.rb' + - 'spec/models/tag_layout_spec.rb' + - 'spec/models/tag_layout_template_spec.rb' + - 'spec/models/tag_set_spec.rb' - 'spec/models/tag_substitutions_spec.rb' + - 'spec/models/tasks/cherrypick_task_spec.rb' + - 'spec/models/transfer_request_collection_spec.rb' + - 'spec/models/transfer_request_spec.rb' + - 'spec/models/tube_rack_spec.rb' + - 'spec/models/well_spec.rb' + - 'spec/requests/api/v2/bait_library_layouts_spec.rb' + - 'spec/requests/api/v2/custom_metadatum_collections_spec.rb' + - 'spec/requests/api/v2/heron/plates_spec.rb' + - 'spec/requests/api/v2/heron/tube_racks_spec.rb' + - 'spec/requests/api/v2/pooled_plate_creations_spec.rb' + - 'spec/requests/api/v2/sample_metadata_spec.rb' + - 'spec/requests/api/v2/specific_tube_creations_spec.rb' + - 'spec/requests/api/v2/state_changes_spec.rb' + - 'spec/requests/api/v2/tag_layouts_spec.rb' + - 'spec/requests/api/v2/transfers/transfers_spec.rb' + - 'spec/requests/api/v2/users_spec.rb' + - 'spec/sample_manifest_excel/upload/processor_spec.rb' + - 'spec/sample_manifest_excel/upload/upload_spec.rb' + - 'spec/sequencescape_excel/specialised_field_spec.rb' + - 'spec/tasks/create_mbrave_tags_spec.rb' + - 'spec/uat_actions/generate_plates_spec.rb' + - 'spec/uat_actions/generate_project_spec.rb' + - 'spec/uat_actions/generate_sample_manifest_spec.rb' + - 'spec/uat_actions/generate_study_spec.rb' + - 'spec/validators/novaseqx_pe_validator_spec.rb' # Offense count: 6 RSpec/RepeatedDescription: @@ -959,6 +1485,7 @@ RSpec/RepeatedExampleGroupDescription: # Offense count: 25 # This cop supports safe autocorrection (--autocorrect). +# Configuration parameters: AutoCorrect. RSpec/ScatteredLet: Exclude: - 'spec/api/plate_spec.rb' @@ -991,6 +1518,51 @@ RSpec/VoidExpect: - 'spec/sample_manifest_excel/test_download_spec.rb' - 'spec/sequencescape_excel/column_spec.rb' +# Offense count: 10 +# This cop supports safe autocorrection (--autocorrect). +RSpecRails/MinitestAssertions: + Exclude: + - 'spec/models/robot/generator/beckman_spec.rb' + - 'spec/models/robot/generator/hamilton_spec.rb' + - 'spec/models/robot/generator/tecan_spec.rb' + - 'spec/models/tag_substitutions_spec.rb' + +# Offense count: 69 +# This cop supports unsafe autocorrection (--autocorrect-all). +Rails/ActionControllerFlashBeforeRender: + Exclude: + - 'app/controllers/admin/bait_libraries/bait_library_suppliers_controller.rb' + - 'app/controllers/admin/bait_libraries/bait_library_types_controller.rb' + - 'app/controllers/admin/bait_libraries_controller.rb' + - 'app/controllers/admin/custom_texts_controller.rb' + - 'app/controllers/admin/faculty_sponsors_controller.rb' + - 'app/controllers/admin/plate_purposes_controller.rb' + - 'app/controllers/admin/primer_panels_controller.rb' + - 'app/controllers/admin/programs_controller.rb' + - 'app/controllers/admin/projects_controller.rb' + - 'app/controllers/admin/robots_controller.rb' + - 'app/controllers/admin/roles_controller.rb' + - 'app/controllers/admin/users_controller.rb' + - 'app/controllers/barcode_printers_controller.rb' + - 'app/controllers/batches_controller.rb' + - 'app/controllers/labware_controller.rb' + - 'app/controllers/location_reports_controller.rb' + - 'app/controllers/plates_controller.rb' + - 'app/controllers/projects_controller.rb' + - 'app/controllers/qc_reports_controller.rb' + - 'app/controllers/quad_stamp_controller.rb' + - 'app/controllers/receptacles_controller.rb' + - 'app/controllers/requests_controller.rb' + - 'app/controllers/samples_controller.rb' + - 'app/controllers/sessions_controller.rb' + - 'app/controllers/studies/asset_groups_controller.rb' + - 'app/controllers/studies_controller.rb' + - 'app/controllers/study_reports_controller.rb' + - 'app/controllers/tag_groups_controller.rb' + - 'app/controllers/tag_layout_templates_controller.rb' + - 'app/controllers/tag_sets_controller.rb' + - 'app/controllers/users_controller.rb' + # Offense count: 2 # This cop supports unsafe autocorrection (--autocorrect-all). Rails/ApplicationMailer: @@ -998,12 +1570,15 @@ Rails/ApplicationMailer: - 'app/mailers/user_query_mailer.rb' - 'lib/eventful_mailer.rb' -# Offense count: 5 +# Offense count: 8 # This cop supports unsafe autocorrection (--autocorrect-all). Rails/CompactBlank: Exclude: + - 'app/bulk_submission_excel/bulk_submission_excel/worksheet/data_worksheet.rb' + - 'app/models/batch.rb' - 'app/models/bulk_submission.rb' - 'app/sample_manifest_excel/sample_manifest_excel/upload/base.rb' + - 'db/migrate/20210813103531_migrate_descriptor_fields_into_descriptors.rb' - 'features/support/step_definitions/delayed_job_steps.rb' - 'lib/event_factory.rb' @@ -1177,6 +1752,12 @@ Rails/LexicallyScopedActionFilter: - 'app/controllers/projects_controller.rb' - 'app/controllers/sdb/sample_manifests_controller.rb' +# Offense count: 1 +# This cop supports unsafe autocorrection (--autocorrect-all). +Rails/NegateInclude: + Exclude: + - 'app/controllers/admin/studies_controller.rb' + # Offense count: 1 # This cop supports unsafe autocorrection (--autocorrect-all). # Configuration parameters: Include. @@ -1201,10 +1782,10 @@ Rails/RakeEnvironment: - 'lib/tasks/views_schema.rake' # Offense count: 1 -# Configuration parameters: TransactionMethods. -Rails/TransactionExitStatement: +# This cop supports unsafe autocorrection (--autocorrect-all). +Rails/RootPathnameMethods: Exclude: - - 'app/models/sample_manifest/uploader.rb' + - 'spec/rails_helper.rb' # Offense count: 5 # This cop supports unsafe autocorrection (--autocorrect-all). @@ -1222,6 +1803,14 @@ Rails/WhereNot: - 'app/models/request.rb' - 'app/models/well.rb' +# Offense count: 3 +# This cop supports unsafe autocorrection (--autocorrect-all). +Rails/WhereRange: + Exclude: + - 'app/models/product_criteria.rb' + - 'db/migrate/20190829125347_populate_labware_table.rb' + - 'db/migrate/20190829125348_populate_receptacles_table.rb' + # Offense count: 5 Security/Eval: Exclude: @@ -1234,14 +1823,11 @@ Security/Open: Exclude: - 'app/api/core/io/json/stream.rb' -# Offense count: 4 +# Offense count: 1 # This cop supports unsafe autocorrection (--autocorrect-all). -Security/YAMLLoad: +Style/ArrayIntersect: Exclude: - - 'app/models/submission/request_options_behaviour.rb' - - 'config/initializers/failure_reasons.rb' - - 'config/initializers/process_locale_files_with_erb.rb' - - 'db/seeds/0001_snp_plate_purposes.rb' + - 'test/unit/flexible_submission_test.rb' # Offense count: 1 # This cop supports safe autocorrection (--autocorrect). @@ -1327,34 +1913,18 @@ Style/Encoding: - 'app/models/sequencing_request.rb' - 'config/initializers/formtastic.rb' -# Offense count: 30 +# Offense count: 10 # This cop supports safe autocorrection (--autocorrect). Style/EvalWithLocation: Exclude: - - 'app/api/core/abilities.rb' - - 'app/api/core/endpoint/basic_handler/actions.rb' - 'app/api/core/endpoint/basic_handler/actions/bound.rb' - - 'app/api/core/endpoint/basic_handler/actions/guards.rb' - - 'app/api/core/endpoint/basic_handler/actions/inner_action.rb' - - 'app/api/core/endpoint/basic_handler/associations/has_many/handler.rb' - 'app/api/core/initializable.rb' - - 'app/api/core/io/base/json_formatting_behaviour/input.rb' - 'app/api/core/logging.rb' - - 'app/api/endpoints/studies.rb' - - 'app/api/endpoints/uuids.rb' - - 'app/models/asset_link.rb' - 'app/models/attributable/association.rb' - 'app/models/attributable/attribute.rb' - - 'app/models/delegate_validation.rb' - - 'app/models/document.rb' - - 'app/models/metadata.rb' - 'app/models/metadata/form_builder.rb' - - 'app/models/request/statistics.rb' - 'app/models/tube.rb' - - 'app/models/validation_state_guard.rb' - 'app/models/well.rb' - - 'features/support/api.rb' - - 'lib/eventful_record.rb' # Offense count: 4 # This cop supports safe autocorrection (--autocorrect). @@ -1400,14 +1970,13 @@ Style/FormatStringToken: - 'lib/label_printer/label_printer/pmb_client.rb' - 'lib/views_schema.rb' -# Offense count: 2 +# Offense count: 1 # This cop supports unsafe autocorrection (--autocorrect-all). # Configuration parameters: EnforcedStyle. # SupportedStyles: always, always_true, never Style/FrozenStringLiteralComment: Exclude: - 'config/initializers/new_framework_defaults_6_1.rb' - - 'config/initializers/permissions_policy.rb' # Offense count: 2 # This cop supports unsafe autocorrection (--autocorrect-all). @@ -1416,12 +1985,11 @@ Style/GlobalStdStream: - 'config/environments/production.rb' - 'lib/tasks/limber_dev.rake' -# Offense count: 46 +# Offense count: 42 # This cop supports safe autocorrection (--autocorrect). # Configuration parameters: MinBodyLength, AllowConsecutiveConditionals. Style/GuardClause: Exclude: - - 'app/bulk_submission_excel/bulk_submission_excel/download.rb' - 'app/controllers/assets_controller.rb' - 'app/controllers/orders_controller.rb' - 'app/controllers/plates_controller.rb' @@ -1505,12 +2073,6 @@ Style/IfInsideElse: - 'app/models/accession_service.rb' - 'app/models/bulk_submission.rb' -# Offense count: 1 -# This cop supports safe autocorrection (--autocorrect). -Style/IfUnlessModifier: - Exclude: - - 'app/models/delegate_validation.rb' - # Offense count: 5 # This cop supports safe autocorrection (--autocorrect). Style/IfUnlessModifierOfIfUnless: @@ -1535,6 +2097,13 @@ Style/LineEndConcatenation: Exclude: - 'features/support/paths.rb' +# Offense count: 2 +# This cop supports unsafe autocorrection (--autocorrect-all). +Style/MapIntoArray: + Exclude: + - 'app/models/plate_barcode.rb' + - 'spec/models/tasks/plate_template_task_spec.rb' + # Offense count: 7 Style/MissingRespondToMissing: Exclude: @@ -1546,13 +2115,6 @@ Style/MissingRespondToMissing: - 'lib/informatics/test/helpers/authentication_helper.rb' - 'lib/validateable.rb' -# Offense count: 1 -# This cop supports safe autocorrection (--autocorrect). -# Configuration parameters: AllowMethodComparison, ComparisonsThreshold. -Style/MultipleComparison: - Exclude: - - 'app/helpers/application_helper.rb' - # Offense count: 4 # This cop supports safe autocorrection (--autocorrect). Style/NegatedIfElseCondition: @@ -1581,22 +2143,6 @@ Style/NestedParenthesizedCalls: - 'app/models/parsers/bioanalysis_csv_parser.rb' - 'lib/label_printer/label_printer/pmb_client.rb' -# Offense count: 1 -# This cop supports safe autocorrection (--autocorrect). -# Configuration parameters: EnforcedStyle, MinBodyLength. -# SupportedStyles: skip_modifier_ifs, always -Style/Next: - Exclude: - - 'app/views/studies/show.xml.builder' - -# Offense count: 1 -# This cop supports safe autocorrection (--autocorrect). -# Configuration parameters: EnforcedStyle. -# SupportedStyles: predicate, comparison -Style/NilComparison: - Exclude: - - 'app/models/parsers/bioanalysis_csv_parser.rb' - # Offense count: 2 # This cop supports safe autocorrection (--autocorrect). # Configuration parameters: IncludeSemanticChanges. @@ -1725,7 +2271,7 @@ Style/ParallelAssignment: - 'test/unit/messaging/hash_generation_test.rb' - 'test/unit/tag_qc/qcable_statemachine_checks.rb' -# Offense count: 4 +# Offense count: 2 # This cop supports safe autocorrection (--autocorrect). # Configuration parameters: AllowSafeAssignment, AllowInMultilineConditions. Style/ParenthesesAroundCondition: @@ -1770,79 +2316,6 @@ Style/RedundantArgument: - 'features/support/step_definitions/samples_steps.rb' - 'spec/features/shared_examples/cherrypicking.rb' -# Offense count: 5 -# This cop supports safe autocorrection (--autocorrect). -Style/RedundantBegin: - Exclude: - - 'app/controllers/bulk_submissions_controller.rb' - - 'app/controllers/studies_controller.rb' - - 'app/models/qc_report.rb' - - 'app/models/request/change_decision.rb' - - 'app/models/submission/project_validation.rb' - -# Offense count: 2 -# This cop supports safe autocorrection (--autocorrect). -Style/RedundantException: - Exclude: - - 'app/models/request.rb' - -# Offense count: 1 -# This cop supports safe autocorrection (--autocorrect). -Style/RedundantFreeze: - Exclude: - - 'lib/psd_formatter.rb' - -# Offense count: 61 -# This cop supports safe autocorrection (--autocorrect). -Style/RedundantParentheses: - Exclude: - - 'app/controllers/admin/studies_controller.rb' - - 'app/models/asset_barcode.rb' - - 'app/models/map.rb' - - 'app/models/parsers/bioanalysis_csv_parser.rb' - - 'app/models/plate/creator_parameters.rb' - - 'app/models/qc_result_factory.rb' - - 'app/models/sequencing_pipeline.rb' - - 'app/models/study.rb' - - 'app/models/user.rb' - - 'app/resources/api/v2/shared_behaviour/labware.rb' - - 'app/sample_manifest_excel/sample_manifest_excel/worksheet/test_worksheet.rb' - - 'app/views/samples/show.xml.builder' - - 'app/views/studies/show.xml.builder' - - 'features/support/step_definitions/debug_steps.rb' - - 'lib/accession/accession/sample.rb' - - 'lib/eventful_mailer.rb' - - 'lib/label_printer/label_printer/label/robot_beds.rb' - - 'lib/manifest_util.rb' - - 'lib/submission_serializer.rb' - - 'lib/tasks/limber.rake' - - 'spec/features/pooling_spec.rb' - - 'spec/features/sample_logistics/lab/stock_stamping_spec.rb' - - 'test/lib/label_printer/plate_creator_test.rb' - - 'test/lib/label_printer/plate_to_tube_test.rb' - - 'test/lib/label_printer/print_job_test.rb' - - 'test/lib/label_printer/sample_manifest_multiplex_test.rb' - - 'test/lib/label_printer/sample_manifest_plate_test.rb' - - 'test/lib/label_printer/sample_manifest_tube_test.rb' - - 'test/lib/label_printer/shared_tests.rb' - - 'test/unit/custom_metadatum_collection_test.rb' - -# Offense count: 10 -# This cop supports safe autocorrection (--autocorrect). -Style/RedundantRegexpEscape: - Exclude: - - 'features/support/step_definitions/api_steps.rb' - - 'features/support/step_definitions/web_form_steps.rb' - - 'features/support/step_definitions/web_steps.rb' - - 'features/support/step_definitions/xml_steps.rb' - -# Offense count: 1 -# This cop supports safe autocorrection (--autocorrect). -# Configuration parameters: AllowMultipleReturnValues. -Style/RedundantReturn: - Exclude: - - 'lib/lab_where_client.rb' - # Offense count: 7 # This cop supports safe autocorrection (--autocorrect). # Configuration parameters: EnforcedStyle. @@ -1857,7 +2330,7 @@ Style/RescueStandardError: - 'app/models/qc_report.rb' - 'app/models/submission/delayed_job_behaviour.rb' -# Offense count: 17 +# Offense count: 18 # This cop supports unsafe autocorrection (--autocorrect-all). # Configuration parameters: ConvertCodeThatCanStartToReturnNil, AllowedMethods, MaxChainLength. # AllowedMethods: present?, blank?, presence, try, try! @@ -1874,13 +2347,6 @@ Style/SafeNavigation: - 'lib/event_factory.rb' - 'test/unit/qc_report_file_test.rb' -# Offense count: 2 -# This cop supports safe autocorrection (--autocorrect). -Style/SelfAssignment: - Exclude: - - 'app/helpers/application_helper.rb' - - 'app/views/batches/released.xml.builder' - # Offense count: 7 # This cop supports unsafe autocorrection (--autocorrect-all). Style/SingleArgumentDig: @@ -1978,6 +2444,19 @@ Style/StringConcatenation: - 'test/unit/product_criteria/basic_test.rb' - 'test/unit/qc_file_test.rb' +# Offense count: 8 +# This cop supports safe autocorrection (--autocorrect). +Style/SuperArguments: + Exclude: + - 'app/api/model_extensions/order.rb' + - 'app/controllers/api/v2/transfers/transfers_controller.rb' + - 'app/models/broadcast_event/plate_cherrypicked.rb' + - 'app/models/pipeline.rb' + - 'app/models/plate_purpose/additional_input.rb' + - 'app/models/qc_result_factory.rb' + - 'app/sample_manifest_excel/sample_manifest_excel/upload/processor/tube_rack.rb' + - 'features/support/accession_service.rb' + # Offense count: 4 # This cop supports unsafe autocorrection (--autocorrect-all). # Configuration parameters: AllowMethodsWithArguments, AllowedMethods, AllowedPatterns, AllowComments. @@ -1989,14 +2468,6 @@ Style/SymbolProc: - 'app/models/tasks/plate_transfer_handler.rb' - 'db/seeds/0001_workflows.rb' -# Offense count: 1 -# This cop supports safe autocorrection (--autocorrect). -# Configuration parameters: EnforcedStyle, AllowSafeAssignment. -# SupportedStyles: require_parentheses, require_no_parentheses, require_parentheses_when_complex -Style/TernaryParentheses: - Exclude: - - 'app/models/parsers/bioanalysis_csv_parser.rb' - # Offense count: 9 # This cop supports unsafe autocorrection (--autocorrect-all). Style/ZeroLengthPredicate: diff --git a/.ruby-version b/.ruby-version index 351227fca3..5ae69bd5f0 100644 --- a/.ruby-version +++ b/.ruby-version @@ -1 +1 @@ -3.2.4 +3.2.5 diff --git a/Dockerfile b/Dockerfile index d42b9dae40..f64ba4780f 100644 --- a/Dockerfile +++ b/Dockerfile @@ -2,8 +2,8 @@ ARG CHIPSET=default # Use the correct base image depending on the architecture # For Apple M1 Chip, run: docker build --build-arg CHIPSET=m1 . -FROM ruby:3.2.4-slim AS base_default -FROM --platform=linux/amd64 ruby:3.2.4-slim AS base_m1 +FROM ruby:3.2.5-slim AS base_default +FROM --platform=linux/amd64 ruby:3.2.5-slim AS base_m1 FROM base_${CHIPSET} AS base COPY .nvmrc /.nvmrc diff --git a/Gemfile b/Gemfile index 51bb14aaab..2c312bb0ba 100644 --- a/Gemfile +++ b/Gemfile @@ -146,9 +146,12 @@ end group :development, :linting do # Enforces coding styles and detects some bad practices gem 'rubocop', require: false + gem 'rubocop-capybara', require: false + gem 'rubocop-factory_bot', require: false gem 'rubocop-performance', require: false gem 'rubocop-rails', require: false gem 'rubocop-rspec', require: false + gem 'rubocop-rspec_rails', require: false gem 'prettier_print', require: false gem 'syntax_tree', require: false diff --git a/Gemfile.lock b/Gemfile.lock index 0437a39463..9dd2a685e4 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -241,7 +241,7 @@ GEM http-accept (1.7.0) http-cookie (1.0.5) domain_name (~> 0.5) - i18n (1.14.5) + i18n (1.14.6) concurrent-ruby (~> 1.0) image_processing (1.12.2) mini_magick (>= 4.9.5, < 5) @@ -258,7 +258,7 @@ GEM listen (3.9.0) rb-fsevent (~> 0.10, >= 0.10.3) rb-inotify (~> 0.9, >= 0.9.10) - logger (1.6.0) + logger (1.6.1) loofah (2.22.0) crass (~> 1.0.2) nokogiri (>= 1.12.0) @@ -305,8 +305,9 @@ GEM racc (~> 1.4) nokogiri (1.16.7-x86_64-linux) racc (~> 1.4) - parallel (1.24.0) - parser (3.3.0.5) + ostruct (0.6.0) + parallel (1.26.3) + parser (3.3.5.0) ast (~> 2.4.1) racc prettier_print (1.2.1) @@ -320,7 +321,7 @@ GEM pry (>= 0.13.0) psych (3.3.4) public_suffix (6.0.0) - puma (6.4.2) + puma (6.4.3) nio4r (~> 2.0) racc (1.8.1) rack (2.2.9) @@ -380,17 +381,16 @@ GEM rb-fsevent (0.11.2) rb-inotify (0.10.1) ffi (~> 1.0) - rbs (3.5.1) + rbs (3.5.3) logger rbtree (0.4.6) - regexp_parser (2.9.0) + regexp_parser (2.9.2) rest-client (2.1.0) http-accept (>= 1.7.0, < 2.0) http-cookie (>= 1.0.2, < 2.0) mime-types (>= 1.16, < 4.0) netrc (~> 0.8) - rexml (3.3.6) - strscan + rexml (3.3.7) roo (2.10.1) nokogiri (~> 1) rubyzip (>= 1.3.0, < 3.0.0) @@ -425,35 +425,35 @@ GEM rspec-mocks (~> 3.13) rspec-support (~> 3.13) rspec-support (3.13.1) - rubocop (1.61.0) + rubocop (1.66.1) json (~> 2.3) language_server-protocol (>= 3.17.0) parallel (~> 1.10) parser (>= 3.3.0.2) rainbow (>= 2.2.2, < 4.0) - regexp_parser (>= 1.8, < 3.0) - rexml (>= 3.2.5, < 4.0) - rubocop-ast (>= 1.30.0, < 2.0) + regexp_parser (>= 2.4, < 3.0) + rubocop-ast (>= 1.32.2, < 2.0) ruby-progressbar (~> 1.7) unicode-display_width (>= 2.4.0, < 3.0) - rubocop-ast (1.31.1) - parser (>= 3.3.0.4) - rubocop-capybara (2.20.0) + rubocop-ast (1.32.3) + parser (>= 3.3.1.0) + rubocop-capybara (2.21.0) rubocop (~> 1.41) - rubocop-factory_bot (2.25.1) - rubocop (~> 1.41) - rubocop-performance (1.20.2) + rubocop-factory_bot (2.26.1) + rubocop (~> 1.61) + rubocop-performance (1.22.1) rubocop (>= 1.48.1, < 2.0) - rubocop-ast (>= 1.30.0, < 2.0) - rubocop-rails (2.24.0) + rubocop-ast (>= 1.31.1, < 2.0) + rubocop-rails (2.26.2) activesupport (>= 4.2.0) rack (>= 1.1) - rubocop (>= 1.33.0, < 2.0) + rubocop (>= 1.52.0, < 2.0) rubocop-ast (>= 1.31.1, < 2.0) - rubocop-rspec (2.27.1) - rubocop (~> 1.40) - rubocop-capybara (~> 2.17) - rubocop-factory_bot (~> 2.22) + rubocop-rspec (3.0.5) + rubocop (~> 1.61) + rubocop-rspec_rails (2.30.0) + rubocop (~> 1.61) + rubocop-rspec (~> 3, >= 3.0.1) ruby-graphviz (1.2.5) rexml ruby-prof (1.7.0) @@ -471,7 +471,7 @@ GEM sanitize (6.1.0) crass (~> 1.0.2) nokogiri (>= 1.12.0) - selenium-webdriver (4.22.0) + selenium-webdriver (4.25.0) base64 (~> 0.2) logger (~> 1.4) rexml (~> 3.2, >= 3.2.5) @@ -507,7 +507,6 @@ GEM activesupport (>= 6.1) sprockets (>= 3.0.0) ssrf_filter (1.1.2) - strscan (3.1.0) syntax_tree (6.2.0) prettier_print (>= 1.2.0) syntax_tree-haml (4.0.3) @@ -521,16 +520,16 @@ GEM sys-uname (1.2.3) ffi (~> 1.1) temple (0.10.3) - test-prof (1.3.3.1) - thor (1.3.1) - tilt (2.3.0) + test-prof (1.4.2) + thor (1.3.2) + tilt (2.4.0) timecop (0.9.10) timeout (0.4.1) traceroute (0.8.1) rails (>= 3.0.0) tzinfo (2.0.6) concurrent-ruby (~> 1.0) - unicode-display_width (2.5.0) + unicode-display_width (2.6.0) uniform_notifier (1.16.0) uuidtools (2.2.0) vite_rails (3.0.17) @@ -544,7 +543,7 @@ GEM addressable (>= 2.8.0) crack (>= 0.3.2) hashdiff (>= 0.4.0, < 2.0.0) - websocket (1.2.10) + websocket (1.2.11) websocket-driver (0.7.6) websocket-extensions (>= 0.1.0) websocket-extensions (0.1.5) @@ -555,14 +554,15 @@ GEM will_paginate (>= 3.0.3) xpath (3.2.0) nokogiri (~> 1.8) - yard (0.9.36) + yard (0.9.37) yard-activerecord (0.0.16) yard (>= 0.8.3) - yard-junk (0.0.9) + yard-junk (0.0.10) backports (>= 3.18) + ostruct rainbow yard - zeitwerk (2.6.17) + zeitwerk (2.6.18) PLATFORMS arm64-darwin @@ -634,9 +634,12 @@ DEPENDENCIES rspec-longrun rspec-rails rubocop + rubocop-capybara + rubocop-factory_bot rubocop-performance rubocop-rails rubocop-rspec + rubocop-rspec_rails ruby-prof ruby-units sanger_barcode_format! diff --git a/README.md b/README.md index ddf679d5a1..a42a5be9d9 100644 --- a/README.md +++ b/README.md @@ -101,8 +101,8 @@ bundle exec yard-junk --sanity The following tools are required for development: - ruby (version defined in the `.ruby-version`) -- yarn -- node (version defined in the `.nvmrc`) +- yarn (`brew install yarn`) +- node (`brew install node@` version defined in the `.nvmrc`, ensure node is in your PATH) - mysql client libraries - if you do not want to install mysql server on your machine, consider using mysql-client: `brew install mysql-client`. Alternatively, to install the MySQL required by Sequencescape (currently 8.0) @@ -220,6 +220,11 @@ bundle exec rails s Once setup, the default user/password is `admin/admin`. +### Vite + +Ensure Node is installed, and in your PATH. You might need to run +`bin/vite build --clear --mode=development` + #### Delayed job For background processing Sequencescape uses `delayed_job` to ensure that the server is running. It @@ -307,6 +312,15 @@ Rubocop is used for linting. bundle exec rubocop ``` +Note that permanent `Exclude`s should be defined in `.rubocop.yml`, with 'temporary' ones +(automatically) listed in `.rubocop_todo.yml`. + +To update `.rubocop_todo.yml`, execute + +```shell +rubocop --auto-gen-config --no-exclude-limit +``` + Prettier is used for formatting. ```shell @@ -314,6 +328,8 @@ yarn prettier --check . yarn prettier --write . ``` +(If prettier is not yet installed, run `yarn`. This should have ben run in `bin/setup`) + - Prettier rules are configured in .prettierrc.json - Whole files can be ignored in .prettierignore - Sections of files can be disabled using #prettier-ignore @@ -389,10 +405,20 @@ cluster formation batch which represents a flowcell. #### MySQL errors when installing -If you are using homebrew with rbenv and run into errors relating to SSL, have a look [here](https://github.com/brianmario/mysql2/issues/795#issuecomment-433219176) +- If you are using homebrew with rbenv and run into errors relating to SSL, have a look [here](https://github.com/brianmario/mysql2/issues/795#issuecomment-433219176) + +- If you are upgrading a homebrew MySQL locally and have an error about a missing libmysqlclient dylib file, you may need to redownload the mysql2 gem to fix it i.e. `bundle install --redownload` + This is because the mysql2 gem is simlinked to the homebrew mysql. -If you are upgrading a homebrew MySQL locally and have an error about a missing libmysqlclient dylib file, you may need to redownload the mysql2 gem to fix it i.e. `bundle install --redownload` -This is because the mysql2 gem is simlinked to the homebrew mysql. +- If bundle install is failing to install the `mysql2` gem, try the below (updating the paths as required): + +``` +gem install mysql2 -v '0.5.6' -- \ +--with-mysql-lib=/opt/homebrew/Cellar/mysql/ \ +--with-mysql-dir=/opt/homebrew/Cellar/mysql/9.0.1_1 \ +--with-mysql-config=/opt/homebrew/Cellar/mysql/9.0.1_1/bin/mysql_config \ +--with-mysql-include=/opt/homebrew/Cellar/mysql/9.0.1_1/include +``` #### Installing on Apple Silicon (M1) diff --git a/app/api/core/endpoint/base.rb b/app/api/core/endpoint/base.rb index c11382b057..18ed6542ca 100644 --- a/app/api/core/endpoint/base.rb +++ b/app/api/core/endpoint/base.rb @@ -57,8 +57,8 @@ def self.extended(base) # This is where you define your actions. # # @return [Void] - def instance(&block) - handler = Class.new(Handler).tap { |handler_class| const_set(:Instance, handler_class) }.new(&block) + def instance(&) + handler = Class.new(Handler).tap { |handler_class| const_set(:Instance, handler_class) }.new(&) handler.instance_variable_set(:@name, name) self.instance_handler = handler end @@ -96,8 +96,8 @@ def self.extended(base) # This is where you define your actions. # # @return [Void] - def model(&block) - handler = Class.new(Handler).tap { |handler_class| const_set(:Model, handler_class) }.new(&block) + def model(&) + handler = Class.new(Handler).tap { |handler_class| const_set(:Model, handler_class) }.new(&) self.model_handler = handler end end diff --git a/app/api/core/endpoint/basic_handler/actions.rb b/app/api/core/endpoint/basic_handler/actions.rb index 4ea6b2e366..b53673131d 100644 --- a/app/api/core/endpoint/basic_handler/actions.rb +++ b/app/api/core/endpoint/basic_handler/actions.rb @@ -95,8 +95,8 @@ def _#{action}(request, response) end end - def action(name, options = {}, &block) - declare_action(name, options, &block) + def action(name, options = {}, &) + declare_action(name, options, &) attach_action(options[:as] || name, name) action_guard(name, options[:if]) if options.key?(:if) end diff --git a/app/api/core/endpoint/basic_handler/actions/bound.rb b/app/api/core/endpoint/basic_handler/actions/bound.rb index 7b244c6d38..9a7b8e7f82 100644 --- a/app/api/core/endpoint/basic_handler/actions/bound.rb +++ b/app/api/core/endpoint/basic_handler/actions/bound.rb @@ -1,8 +1,8 @@ # frozen_string_literal: true module Core::Endpoint::BasicHandler::Actions::Bound - def bind_action(name, options, &block) + def bind_action(name, options, &) class_handler = Class.new(Handler).tap { |handler| self.class.const_set(options[:as].to_s.camelize, handler) } - register_handler(options[:to], class_handler.new(self, name, options, &block)) + register_handler(options[:to], class_handler.new(self, name, options, &)) end def self.delegate_to_bound_handler(name, target = name) diff --git a/app/api/core/endpoint/basic_handler/actions/bound/handler.rb b/app/api/core/endpoint/basic_handler/actions/bound/handler.rb index 0d894be764..66b504e449 100644 --- a/app/api/core/endpoint/basic_handler/actions/bound/handler.rb +++ b/app/api/core/endpoint/basic_handler/actions/bound/handler.rb @@ -6,8 +6,8 @@ class Core::Endpoint::BasicHandler::Actions::Bound::Handler < Core::Endpoint::Ba include Core::Endpoint::BasicHandler::Actions::InnerAction include Core::Endpoint::BasicHandler::Paged - def initialize(owner, name, options, &block) - super(name, options, &block) + def initialize(owner, name, options, &) + super(name, options, &) @owner = owner end diff --git a/app/api/core/endpoint/basic_handler/actions/factory.rb b/app/api/core/endpoint/basic_handler/actions/factory.rb index 9b1e8327e0..bc80fdb6c2 100644 --- a/app/api/core/endpoint/basic_handler/actions/factory.rb +++ b/app/api/core/endpoint/basic_handler/actions/factory.rb @@ -1,8 +1,8 @@ # frozen_string_literal: true module Core::Endpoint::BasicHandler::Actions::Factory class Nested < Core::Endpoint::BasicHandler - def initialize(name, &block) - super(&block) + def initialize(name, &) + super(&) @name = name.to_s end @@ -16,13 +16,13 @@ def separate(associations, _) end end - def core_path(*args) - super(@name, *args) + def core_path(*) + super(@name, *) end end - def nested(json, &block) + def nested(json, &) class_handler = Class.new(Nested).tap { |handler| self.class.const_set(json.to_s.camelize, handler) } - register_handler(json, class_handler.new(json, &block)) + register_handler(json, class_handler.new(json, &)) end end diff --git a/app/api/core/endpoint/basic_handler/actions/guards.rb b/app/api/core/endpoint/basic_handler/actions/guards.rb index fcf29c54ba..3475b16979 100644 --- a/app/api/core/endpoint/basic_handler/actions/guards.rb +++ b/app/api/core/endpoint/basic_handler/actions/guards.rb @@ -50,8 +50,8 @@ def method_missing(name, ...) protected :method_missing end - def check_authorisation!(*args) - accessible_action?(*args) or + def check_authorisation!(*) + accessible_action?(*) or raise ::Core::Service::UnsupportedAction, 'requested action is not supported on this resource' end private :check_authorisation! @@ -61,8 +61,8 @@ def accessible_action?(_handler, action, request, object) end private :accessible_action? - def action_guard(name, method_name = nil, &block) - guard_for(name).push(Guard.new(method_name, &block)) + def action_guard(name, method_name = nil, &) + guard_for(name).push(Guard.new(method_name, &)) end def guard_for(name) diff --git a/app/api/core/endpoint/basic_handler/actions/inner_action.rb b/app/api/core/endpoint/basic_handler/actions/inner_action.rb index 161a760e3e..b018b4fdc1 100644 --- a/app/api/core/endpoint/basic_handler/actions/inner_action.rb +++ b/app/api/core/endpoint/basic_handler/actions/inner_action.rb @@ -20,15 +20,15 @@ def for_json nil end - def rooted_json(options, &block) + def rooted_json(options, &) return yield(options[:stream]) if @options.key?(:json) - options[:stream].block(@options[:json].to_s, &block) + options[:stream].block(@options[:json].to_s, &) end private :rooted_json def generate_json_actions(object, options) - rooted_json(options) { |stream| super(object, options.merge(stream: stream)) } + rooted_json(options) { |stream| super(object, options.merge(stream:)) } end def declare_action(name, _options) # rubocop:todo Metrics/MethodLength @@ -46,8 +46,8 @@ def _#{name}(request, response) end private :declare_action - def core_path(*args) - super(@options[:to], *args) + def core_path(*) + super(@options[:to], *) end private :core_path end diff --git a/app/api/core/endpoint/basic_handler/associations/belongs_to.rb b/app/api/core/endpoint/basic_handler/associations/belongs_to.rb index 1e5403cd88..4ad0a73799 100644 --- a/app/api/core/endpoint/basic_handler/associations/belongs_to.rb +++ b/app/api/core/endpoint/basic_handler/associations/belongs_to.rb @@ -62,9 +62,9 @@ def initialize @endpoints = [] end - def belongs_to(name, options, &block) + def belongs_to(name, options, &) class_handler = Class.new(Handler).tap { |handler| self.class.const_set(name.to_s.camelize, handler) } - @endpoints.push(class_handler.new(name, options, &block)) + @endpoints.push(class_handler.new(name, options, &)) end def related diff --git a/app/api/core/endpoint/basic_handler/associations/has_many.rb b/app/api/core/endpoint/basic_handler/associations/has_many.rb index dfc9e968f0..c4110e31a9 100644 --- a/app/api/core/endpoint/basic_handler/associations/has_many.rb +++ b/app/api/core/endpoint/basic_handler/associations/has_many.rb @@ -12,8 +12,8 @@ module Core::Endpoint::BasicHandler::Associations::HasMany # @yield [] Use block to define additional actions on the association. # # @return [Void] - def has_many(name, options, &block) + def has_many(name, options, &) class_handler = Class.new(Handler).tap { |handler| self.class.const_set(name.to_s.camelize, handler) } - register_handler(options[:to], class_handler.new(name, options, &block)) + register_handler(options[:to], class_handler.new(name, options, &)) end end diff --git a/app/api/core/endpoint/basic_handler/associations/has_many/handler.rb b/app/api/core/endpoint/basic_handler/associations/has_many/handler.rb index faa6e56e2b..d6566fb9f1 100644 --- a/app/api/core/endpoint/basic_handler/associations/has_many/handler.rb +++ b/app/api/core/endpoint/basic_handler/associations/has_many/handler.rb @@ -2,8 +2,8 @@ class Core::Endpoint::BasicHandler::Associations::HasMany::Handler < Core::Endpoint::BasicHandler include Core::Endpoint::BasicHandler::Paged - def initialize(association, options, &block) - super(&block) + def initialize(association, options, &) + super(&) @association, @options = association, options end diff --git a/app/api/core/io/json/grammar.rb b/app/api/core/io/json/grammar.rb index 45411559e0..f6e2e2e47e 100644 --- a/app/api/core/io/json/grammar.rb +++ b/app/api/core/io/json/grammar.rb @@ -100,10 +100,10 @@ def call(object, options, stream) end end - def rooted_json(stream, nested, &block) + def rooted_json(stream, nested, &) return yield(stream) if nested - stream.block(json_root, &block) + stream.block(json_root, &) end private :rooted_json diff --git a/app/api/core/service.rb b/app/api/core/service.rb index aef4957cc7..2ea9b16d41 100644 --- a/app/api/core/service.rb +++ b/app/api/core/service.rb @@ -99,12 +99,12 @@ def api_path(*sub_path) "#{request.scheme}://#{request.host_with_port}/#{self.class.api_version_path}/#{sub_path.compact.join('/')}" end - def self.before_all_actions(&block) - before('/*', &block) + def self.before_all_actions(&) + before('/*', &) end - def self.after_all_actions(&block) - after('/*', &block) + def self.after_all_actions(&) + after('/*', &) end attr_reader :command @@ -126,9 +126,9 @@ class Request delegate :user, to: :service - def initialize(identifier, *args, &block) + def initialize(identifier, *, &) @identifier, @started_at = identifier, Time.zone.now - super(*args, &block) + super(*, &) @ability = Core::Abilities.create(self) end @@ -143,8 +143,8 @@ def authentication_code @service.request.cookies['api_key'] || @service.request.cookies['WTSISignOn'] end - def response(&block) - ::Core::Service::Response.new(self, &block) + def response(&) + ::Core::Service::Response.new(self, &) end # Safe way to push a particular value on to the request target stack. Ensures that the @@ -216,10 +216,10 @@ def multiple_choices delegate :endpoint_for_object, to: 'request.service' private :endpoint_for_object - def initialize(request, &block) + def initialize(request, &) @request, @io, @include_actions = request, nil, true status(200) - super(&block) + super(&) end #-- diff --git a/app/api/model_extensions/order.rb b/app/api/model_extensions/order.rb index 1dad43d300..dfd6299b71 100644 --- a/app/api/model_extensions/order.rb +++ b/app/api/model_extensions/order.rb @@ -71,8 +71,7 @@ def <<(associated) end end - scope :that_submitted_asset_id, - ->(asset_id) { where(submitted_assets: { asset_id: asset_id }).joins(:submitted_assets) } + scope :that_submitted_asset_id, ->(asset_id) { where(submitted_assets: { asset_id: }).joins(:submitted_assets) } validate :extended_validation def extended_validation diff --git a/app/api/model_extensions/sample.rb b/app/api/model_extensions/sample.rb index 8dbdbdd93c..5827f1fd32 100644 --- a/app/api/model_extensions/sample.rb +++ b/app/api/model_extensions/sample.rb @@ -19,6 +19,6 @@ def sample_reference_genome_name end def sample_reference_genome_name=(name) - sample_metadata.reference_genome = ReferenceGenome.find_by(name: name) + sample_metadata.reference_genome = ReferenceGenome.find_by(name:) end end diff --git a/app/bulk_submission_excel/bulk_submission_excel/download.rb b/app/bulk_submission_excel/bulk_submission_excel/download.rb index cbe1e26fc3..f3ac36104b 100644 --- a/app/bulk_submission_excel/bulk_submission_excel/download.rb +++ b/app/bulk_submission_excel/bulk_submission_excel/download.rb @@ -22,13 +22,12 @@ def new_record? end def ranges_worksheet - if valid? - @ranges_worksheet ||= SequencescapeExcel::Worksheet::RangesWorksheet.new(ranges: range_list, workbook: workbook) - end + @ranges_worksheet ||= + SequencescapeExcel::Worksheet::RangesWorksheet.new(ranges: range_list, workbook: workbook) if valid? end def submission_template_id=(id) - self.submission_template = SubmissionTemplate.find_by(id: id) + self.submission_template = SubmissionTemplate.find_by(id:) end def submission_template_id diff --git a/app/controllers/admin/studies_controller.rb b/app/controllers/admin/studies_controller.rb index c7ed458f2e..06616c4b8d 100644 --- a/app/controllers/admin/studies_controller.rb +++ b/app/controllers/admin/studies_controller.rb @@ -42,7 +42,7 @@ def filter # rubocop:todo Metrics/CyclomaticComplexity unless params[:filter].nil? if params[:filter][:by] == 'unallocated manager' - @studies = Study.select { |p| p.name.include?(params[:q]) && !(p.roles.map(&:name).include?('manager')) } + @studies = Study.select { |p| p.name.include?(params[:q]) && !p.roles.map(&:name).include?('manager') } end end diff --git a/app/controllers/admin/users_controller.rb b/app/controllers/admin/users_controller.rb index 1de54c7c4f..0b29372eb8 100644 --- a/app/controllers/admin/users_controller.rb +++ b/app/controllers/admin/users_controller.rb @@ -56,11 +56,11 @@ def grant_user_role # rubocop:todo Metrics/AbcSize, Metrics/MethodLength @user.grant_role(params[:role][:authorizable_name].to_s, authorizable_object) @users_roles = @user.study_and_project_roles.order(name: :asc) - flash[:notice] = 'Role added' # rubocop:disable Rails/ActionControllerFlashBeforeRender + flash[:notice] = 'Role added' render partial: 'roles', status: 200 else @users_roles = @user.study_and_project_roles.order(name: :asc) - flash[:error] = 'A problem occurred while adding the role' # rubocop:disable Rails/ActionControllerFlashBeforeRender + flash[:error] = 'A problem occurred while adding the role' render partial: 'roles', status: 500 end else @@ -82,11 +82,11 @@ def remove_user_role # rubocop:todo Metrics/AbcSize, Metrics/MethodLength @user.remove_role(params[:role][:authorizable_name].to_s, authorizable_object) @users_roles = @user.study_and_project_roles.order(name: :asc) - flash[:error] = 'Role was removed' # rubocop:disable Rails/ActionControllerFlashBeforeRender + flash[:error] = 'Role was removed' render partial: 'roles', status: 200 else @users_roles = @user.study_and_project_roles.order(name: :asc) - flash[:error] = 'A problem occurred while removing the role' # rubocop:disable Rails/ActionControllerFlashBeforeRender + flash[:error] = 'A problem occurred while removing the role' render partial: 'roles', status: 500 end else diff --git a/app/controllers/api/v2/bait_library_layouts_controller.rb b/app/controllers/api/v2/bait_library_layouts_controller.rb new file mode 100644 index 0000000000..f518fdb834 --- /dev/null +++ b/app/controllers/api/v2/bait_library_layouts_controller.rb @@ -0,0 +1,79 @@ +# frozen_string_literal: true + +module Api + module V2 + # Provides a JSON API controller for BaitLibraryLayouts + # See: http://jsonapi-resources.com/ for JSONAPI::Resource documentation + class BaitLibraryLayoutsController < JSONAPI::ResourceController + # By default JSONAPI::ResourceController provides most the standard behaviour, and in many cases this file may be + # left empty. + # However, to remain consistent with functionality of API v1, we have included a custom preview method here. + + # Preview the layout of the bait libraries on a plate. + # This method is not part of the JSONAPI::ResourceController standard actions. + # + # @example Preview a {BaitLibraryLayout} with the given User and Plate identified by UUIDs + # POST /api/v2/bait_library_layouts/preview + # { + # "user_uuid": "11111111-2222-3333-4444-555555666666", + # "plate_uuid": "22222222-3333-4444-5555-666666777777" + # } + # + # @return [JSON] The JSON representation of a sparsely populated {BaitLibraryLayoutResource}. + # Only the `layout` attribute is included. + # No `id` is included as this is a preview and not a persisted record. + def preview + records = preview_records + return if records.nil? + + # Catch the layout preview failing validation. + begin + preview = BaitLibraryLayout.preview!(user: records[:user], plate: records[:plate]) + rescue ActiveRecord::RecordInvalid => e + respond_with_errors('Validation failed', e.record.errors.full_messages, :unprocessable_entity) and return + end + + json = { data: { type: 'bait_library_layouts', attributes: { layout: preview.layout } } } + render json: json, status: :ok + end + + private + + def respond_with_errors(title, details, status) + status_code = Rack::Utils::SYMBOL_TO_STATUS_CODE[status] + + errors = details.map { |detail| { title: title, detail: detail, code: status_code, status: status_code } } + + render json: { errors: }, status: status + end + + # This should only be called once per request, as it will render an exception every time it's called when any one + # of the required parameters are not present. + def permitted_params + param_keys = %i[user_uuid plate_uuid] + param_keys.zip(params.require(param_keys)).to_h + rescue ActionController::ParameterMissing => e + respond_with_errors('Missing parameter', [e.message], :bad_request) and return + end + + def preview_records + param_hash = permitted_params + return if param_hash.nil? + + record_errors = [] + + user = + User.with_uuid(param_hash[:user_uuid]).first || + record_errors.append("The User record identified by UUID '#{param_hash[:user_uuid]}' cannot be found") + + plate = + Plate.with_uuid(param_hash[:plate_uuid]).first || + record_errors.append("The Plate record identified by UUID '#{param_hash[:plate_uuid]}' cannot be found") + + respond_with_errors('Record not found', record_errors, :bad_request) and return if record_errors.any? + + { user:, plate: } + end + end + end +end diff --git a/app/controllers/api/v2/bioscan/export_pool_xp_to_traction_controller.rb b/app/controllers/api/v2/bioscan/export_pool_xp_to_traction_controller.rb index f7daa808ec..f1675569ec 100644 --- a/app/controllers/api/v2/bioscan/export_pool_xp_to_traction_controller.rb +++ b/app/controllers/api/v2/bioscan/export_pool_xp_to_traction_controller.rb @@ -12,7 +12,7 @@ def create Rails.logger.debug { "Creating export_pool_xp_to_traction job for tube with barcode '#{barcode}'" } errors = preflight_errors(barcode) - render json: { errors: errors }, status: :unprocessable_entity and return unless errors.empty? + render json: { errors: }, status: :unprocessable_entity and return unless errors.empty? Delayed::Job.enqueue ExportPoolXpToTractionJob.new(barcode) render json: {}, status: :ok diff --git a/app/controllers/api/v2/pooled_plate_creations_controller.rb b/app/controllers/api/v2/pooled_plate_creations_controller.rb new file mode 100644 index 0000000000..07a8524041 --- /dev/null +++ b/app/controllers/api/v2/pooled_plate_creations_controller.rb @@ -0,0 +1,12 @@ +# frozen_string_literal: true + +module Api + module V2 + # Provides a JSON API controller for Pooled Plate Creations + # See: http://jsonapi-resources.com/ for JSONAPI::Resource documentation + class PooledPlateCreationsController < JSONAPI::ResourceController + # By default JSONAPI::ResourceController provides most the standard + # behaviour, and in many cases this file may be left empty. + end + end +end diff --git a/app/controllers/api/v2/request_metadata_controller.rb b/app/controllers/api/v2/request_metadata_controller.rb new file mode 100644 index 0000000000..1145c42c0d --- /dev/null +++ b/app/controllers/api/v2/request_metadata_controller.rb @@ -0,0 +1,12 @@ +# frozen_string_literal: true + +module Api + module V2 + # Provides a JSON API controller for RequestMetadata + # See: http://jsonapi-resources.com/ for JSONAPI::Resource documentation + class RequestMetadataController < JSONAPI::ResourceController + # By default JSONAPI::ResourceController provides most the standard + # behaviour, and in many cases this file may be left empty. + end + end +end diff --git a/app/controllers/api/v2/specific_tube_creations_controller.rb b/app/controllers/api/v2/specific_tube_creations_controller.rb new file mode 100644 index 0000000000..0b3d3ec94e --- /dev/null +++ b/app/controllers/api/v2/specific_tube_creations_controller.rb @@ -0,0 +1,12 @@ +# frozen_string_literal: true + +module Api + module V2 + # Provides a JSON API controller for Specific Tube Creations + # See: http://jsonapi-resources.com/ for JSONAPI::Resource documentation + class SpecificTubeCreationsController < JSONAPI::ResourceController + # By default JSONAPI::ResourceController provides most the standard + # behaviour, and in many cases this file may be left empty. + end + end +end diff --git a/app/controllers/api/v2/tag_layouts_controller.rb b/app/controllers/api/v2/tag_layouts_controller.rb new file mode 100644 index 0000000000..168e2197be --- /dev/null +++ b/app/controllers/api/v2/tag_layouts_controller.rb @@ -0,0 +1,12 @@ +# frozen_string_literal: true + +module Api + module V2 + # Provides a JSON API controller for Tag Layouts + # See: http://jsonapi-resources.com/ for JSONAPI::Resource documentation + class TagLayoutsController < JSONAPI::ResourceController + # By default JSONAPI::ResourceController provides most the standard + # behaviour, and in many cases this file may be left empty. + end + end +end diff --git a/app/controllers/bulk_submissions_controller.rb b/app/controllers/bulk_submissions_controller.rb index 8b524c0630..098dacf7a1 100644 --- a/app/controllers/bulk_submissions_controller.rb +++ b/app/controllers/bulk_submissions_controller.rb @@ -23,21 +23,19 @@ def new # rubocop:todo Metrics/MethodLength def create # rubocop:todo Metrics/AbcSize - begin - @bulk_submission = BulkSubmission.new(params.fetch(:bulk_submission, {})) - if @bulk_submission.valid? - flash.now[:notice] = 'File was processed successfully' - sub_ids, @sub_details = @bulk_submission.completed_submissions - @these_subs = Submission.find(sub_ids) - else - flash.now[:error] = 'There was a problem with your upload' - render action: 'new' - end - rescue ActiveRecord::RecordInvalid => e - flash.now[:error] = 'There was a problem when building your submissions' - @bulk_submission.errors.add(:base, e.message) + @bulk_submission = BulkSubmission.new(params.fetch(:bulk_submission, {})) + if @bulk_submission.valid? + flash.now[:notice] = 'File was processed successfully' + sub_ids, @sub_details = @bulk_submission.completed_submissions + @these_subs = Submission.find(sub_ids) + else + flash.now[:error] = 'There was a problem with your upload' render action: 'new' end + rescue ActiveRecord::RecordInvalid => e + flash.now[:error] = 'There was a problem when building your submissions' + @bulk_submission.errors.add(:base, e.message) + render action: 'new' end # rubocop:enable Metrics/MethodLength diff --git a/app/controllers/plates_controller.rb b/app/controllers/plates_controller.rb index 95c6499895..f76d55eaed 100644 --- a/app/controllers/plates_controller.rb +++ b/app/controllers/plates_controller.rb @@ -30,7 +30,7 @@ def create # rubocop:todo Metrics/AbcSize respond_to do |format| if scanned_user.nil? - flash[:error] = 'Please scan your user barcode' # rubocop:disable Rails/ActionControllerFlashBeforeRender + flash[:error] = 'Please scan your user barcode' elsif tube_rack_sources? plate_creator.create_plates_from_tube_racks!(tube_racks, barcode_printer, scanned_user, create_asset_group) else @@ -43,7 +43,7 @@ def create # rubocop:todo Metrics/AbcSize ) end flash[:notice] = 'Created plates successfully' - flash[:warning] = plate_creator.warnings if plate_creator.warnings.present? # rubocop:disable Rails/ActionControllerFlashBeforeRender + flash[:warning] = plate_creator.warnings if plate_creator.warnings.present? format.html { render(new_plate_path) } end rescue StandardError => e diff --git a/app/controllers/projects_controller.rb b/app/controllers/projects_controller.rb index d495a8f524..3c8b099f9d 100644 --- a/app/controllers/projects_controller.rb +++ b/app/controllers/projects_controller.rb @@ -130,11 +130,11 @@ def grant_role # rubocop:todo Metrics/AbcSize if params[:role] @user.grant_role(params[:role][:authorizable_type].to_s, @project) @roles = @project.roles - flash[:notice] = 'Role added' # rubocop:disable Rails/ActionControllerFlashBeforeRender + flash[:notice] = 'Role added' render partial: 'roles', status: 200 else @roles = @project.roles - flash[:error] = 'A problem occurred while adding the role' # rubocop:disable Rails/ActionControllerFlashBeforeRender + flash[:error] = 'A problem occurred while adding the role' render partial: 'roles', status: 500 end else @@ -156,11 +156,11 @@ def remove_role # rubocop:todo Metrics/AbcSize if params[:role] @user.remove_role(params[:role][:authorizable_type].to_s, @project) @roles = @project.roles - flash[:error] = 'Role was removed' # rubocop:disable Rails/ActionControllerFlashBeforeRender + flash[:error] = 'Role was removed' render partial: 'roles', status: 200 else @roles = @project.roles - flash[:error] = 'A problem occurred while removing the role' # rubocop:disable Rails/ActionControllerFlashBeforeRender + flash[:error] = 'A problem occurred while removing the role' render partial: 'roles', status: 500 end else diff --git a/app/controllers/requests_controller.rb b/app/controllers/requests_controller.rb index 62b0cf9878..f5ed92db97 100644 --- a/app/controllers/requests_controller.rb +++ b/app/controllers/requests_controller.rb @@ -82,7 +82,7 @@ def update # rubocop:todo Metrics/AbcSize flash[:notice] = 'Request details have been updated' redirect_to request_path(@request) else - flash[:error] = 'Request was not updated. No change specified ?' # rubocop:disable Rails/ActionControllerFlashBeforeRender + flash[:error] = 'Request was not updated. No change specified ?' render action: 'edit', id: @request.id end rescue => e diff --git a/app/controllers/studies_controller.rb b/app/controllers/studies_controller.rb index a202258b68..7b12853eed 100644 --- a/app/controllers/studies_controller.rb +++ b/app/controllers/studies_controller.rb @@ -370,13 +370,11 @@ def studies_from_scope(scope) # rubocop:todo Metrics/CyclomaticComplexity # rubocop:enable Metrics/AbcSize, Metrics/MethodLength def rescue_validation - begin - yield - rescue ActiveRecord::RecordInvalid - Rails.logger.warn "Failed to update attributes: #{@study.errors.map { |error| error.to_s }}" # rubocop:disable Style/SymbolProc - flash.now[:error] = 'Failed to update attributes for study!' - render action: 'edit', id: @study.id - end + yield + rescue ActiveRecord::RecordInvalid + Rails.logger.warn "Failed to update attributes: #{@study.errors.map { |error| error.to_s }}" # rubocop:disable Style/SymbolProc + flash.now[:error] = 'Failed to update attributes for study!' + render action: 'edit', id: @study.id end end # rubocop:enable Metrics/ClassLength diff --git a/app/frontend/.eslintrc.js b/app/frontend/.eslintrc.js index 9131da78f5..5325db6df8 100644 --- a/app/frontend/.eslintrc.js +++ b/app/frontend/.eslintrc.js @@ -11,6 +11,7 @@ module.exports = { parserOptions: { parser: "babel-eslint", sourceType: "module", + ecmaVersion: 2018, }, rules: { "no-unused-vars": [ diff --git a/app/helpers/application_helper.rb b/app/helpers/application_helper.rb index 9db8efe1ab..eec978db39 100644 --- a/app/helpers/application_helper.rb +++ b/app/helpers/application_helper.rb @@ -8,7 +8,7 @@ def custom_text(identifier, differential = nil) Rails .cache .fetch("#{identifier}-#{differential}") do - custom_text = CustomText.find_by(identifier: identifier, differential: differential) + custom_text = CustomText.find_by(identifier:, differential:) custom_text.try(:content) || '' end @@ -243,23 +243,17 @@ def tab(name, target: nil, active: false, id: nil) #
# yield #
- def tab_pane(name, id: nil, tab_id: nil, active: false, &block) + def tab_pane(name, id: nil, tab_id: nil, active: false, &) tab_id ||= "#{name}-tab".parameterize id ||= name.parameterize active_class = active ? 'active' : '' - tag.div( - class: ['tab-pane', 'fade', 'show', active_class], - id: id, - role: 'tabpanel', - aria_labelledby: tab_id, - &block - ) + tag.div(class: ['tab-pane', 'fade', 'show', active_class], id: id, role: 'tabpanel', aria_labelledby: tab_id, &) end def display_boolean_results(result) return 'NA' if result.blank? - if result == 'pass' || result == '1' || result == 'true' + if %w[pass 1 true].include?(result) icon('far', 'check-circle', title: result) else icon('fas', 'exclamation-circle', class: 'text-danger', title: result) @@ -270,7 +264,7 @@ def sorted_requests_for_search(requests) sorted_requests = requests.select { |r| r.pipeline_id.nil? } new_requests = requests - sorted_requests new_requests.sort_by(&:pipeline_id) - requests = requests + sorted_requests + requests += sorted_requests end # Creates a label that is hidden from the view so that testing is easier @@ -278,8 +272,8 @@ def hidden_label_tag_for_testing(name, text = nil, options = {}) label_tag(name, text, options.merge(style: 'display:none;')) end - def help_text(&block) - tag.small(class: 'form-text text-muted col', &block) + def help_text(&) + tag.small(class: 'form-text text-muted col', &) end def help_link(text, entry = '', options = {}) diff --git a/app/helpers/assets_helper.rb b/app/helpers/assets_helper.rb index 23c43893af..2b52f81545 100644 --- a/app/helpers/assets_helper.rb +++ b/app/helpers/assets_helper.rb @@ -41,10 +41,10 @@ def new_request_receptacle_path_in_context(asset) # parameter along with its current value, based either on the instance variable ID value or the # ID parameter. For instance, if the 'name' is 'foo' then either the '@foo.id' value will be yielded, # or the 'params[:foo_id]' value if @foo is nil. - def instance_variable_or_id_param(name, &block) + def instance_variable_or_id_param(name, &) field_name, value = :"#{name}_id", instance_variable_get(:"@#{name}") value_id = value.nil? ? params[field_name] : value.id - concat(capture(field_name, value_id, &block)) + concat(capture(field_name, value_id, &)) end # Returns a select tag that has it's options ordered by name (assumes present of sorted_by_name function) diff --git a/app/helpers/bootstrap_helper.rb b/app/helpers/bootstrap_helper.rb index 2b50fca449..be46cd96f4 100644 --- a/app/helpers/bootstrap_helper.rb +++ b/app/helpers/bootstrap_helper.rb @@ -3,20 +3,20 @@ # A collection of view helpers to assist with rendering bootstrap components module BootstrapHelper - def panel(type = :default, options = {}, &block) - bs_custom_panel(type, :div, { class: 'card-body' }, options, &block) + def panel(type = :default, options = {}, &) + bs_custom_panel(type, :div, { class: 'card-body' }, options, &) end - def list_panel(type = :default, options = {}, &block) - bs_custom_panel(type, :ul, { class: 'list-group list-group-flush' }, options, &block) + def list_panel(type = :default, options = {}, &) + bs_custom_panel(type, :ul, { class: 'list-group list-group-flush' }, options, &) end - def link_panel(type = :default, options = {}, &block) - bs_custom_panel(type, :div, { class: 'link-panel' }, options, &block) + def link_panel(type = :default, options = {}, &) + bs_custom_panel(type, :div, { class: 'link-panel' }, options, &) end - def panel_no_body(type = :default, options = {}, &block) - bs_custom_panel(type, :div, {}, options, &block) + def panel_no_body(type = :default, options = {}, &) + bs_custom_panel(type, :div, {}, options, &) end def bs_custom_panel(type, body_type, body_options, options, &block) @@ -31,10 +31,10 @@ def bs_custom_panel(type, body_type, body_options, options, &block) # - def alert(type = :default, options = {}, &block) + def alert(type = :default, options = {}, &) options[:role] ||= 'alert' append_class!(options, "alert alert-#{type}") - tag.div(**options, &block) + tag.div(**options, &) end # Summary composites a panel with a table to deliver @@ -92,12 +92,12 @@ def pagination(collection) end #
- def form_group(&block) - tag.div(class: 'form-group row sqs-form', &block) + def form_group(&) + tag.div(class: 'form-group row sqs-form', &) end - def bs_column(size = 6, screen = 'md', &block) - tag.div(class: "col-#{screen}-#{size}", &block) + def bs_column(size = 6, screen = 'md', &) + tag.div(class: "col-#{screen}-#{size}", &) end def progress_bar(count) # rubocop:todo Metrics/MethodLength diff --git a/app/helpers/descriptor_javascript_helper.rb b/app/helpers/descriptor_javascript_helper.rb index fa3e84cb23..b7cd7f987d 100644 --- a/app/helpers/descriptor_javascript_helper.rb +++ b/app/helpers/descriptor_javascript_helper.rb @@ -1,12 +1,12 @@ # frozen_string_literal: true module DescriptorJavascriptHelper - def link_to_remove_asset(index, &block) - link_to_with_onclick_only("removeAsset(#{index});return false;", &block) + def link_to_remove_asset(index, &) + link_to_with_onclick_only("removeAsset(#{index});return false;", &) end private - def link_to_with_onclick_only(on_click_code, &block) - concat(tag.a(capture(&block), href: 'javascript:void();', onClick: on_click_code)) + def link_to_with_onclick_only(on_click_code, &) + concat(tag.a(capture(&), href: 'javascript:void();', onClick: on_click_code)) end end diff --git a/app/helpers/submissions_helper.rb b/app/helpers/submissions_helper.rb index 3ab2308b58..8eac8eb73d 100644 --- a/app/helpers/submissions_helper.rb +++ b/app/helpers/submissions_helper.rb @@ -38,15 +38,7 @@ def studies_select(form, studies) # rubocop:todo Metrics/MethodLength 'Please select a Study for this Submission...' end - form.collection_select( - :study_id, - studies, - :id, - :name, - { prompt: prompt }, - disabled: true, - class: 'study_id custom-select' - ) + form.collection_select(:study_id, studies, :id, :name, { prompt: }, disabled: true, class: 'study_id custom-select') end def projects_select(form, projects) # rubocop:todo Metrics/MethodLength @@ -62,7 +54,7 @@ def projects_select(form, projects) # rubocop:todo Metrics/MethodLength projects, :name, :name, - { prompt: prompt }, + { prompt: }, disabled: true, class: 'submission_project_name custom-select' ) @@ -83,7 +75,7 @@ def asset_group_select(asset_groups) # rubocop:todo Metrics/MethodLength asset_groups, :id, :name, - { prompt: prompt }, + { prompt: }, class: 'submission_asset_group_id required form-control', disabled: asset_groups.empty? ) diff --git a/app/heron/factories/concerns/contents.rb b/app/heron/factories/concerns/contents.rb index 05ebc98754..445baec59b 100644 --- a/app/heron/factories/concerns/contents.rb +++ b/app/heron/factories/concerns/contents.rb @@ -80,7 +80,7 @@ def params_for_contents def _factories_for_location(location, samples_params) samples_params.each_with_index.map do |sample_params, pos| - sample_params = sample_params.merge(study_uuid: study_uuid) if study_uuid + sample_params = sample_params.merge(study_uuid:) if study_uuid factory = content_factory.new(sample_params) unless factory.valid? label = label_for_error_message(location, pos, samples_params) diff --git a/app/heron/factories/sample.rb b/app/heron/factories/sample.rb index 263f90d827..883daf85f5 100644 --- a/app/heron/factories/sample.rb +++ b/app/heron/factories/sample.rb @@ -105,7 +105,7 @@ def params_for_sample_creation end def params_for_aliquot_creation - { sample: sample, study: study }.merge(@params.dig(:aliquot) || {}) + { sample:, study: }.merge(@params.dig(:aliquot) || {}) end def params_for_sample_table diff --git a/app/heron/factories/tube_rack.rb b/app/heron/factories/tube_rack.rb index 03ac010e76..59dd7cef3d 100644 --- a/app/heron/factories/tube_rack.rb +++ b/app/heron/factories/tube_rack.rb @@ -50,7 +50,7 @@ def save return false unless valid? ActiveRecord::Base.transaction do - @tube_rack = ::TubeRack.create!(size: size, purpose: purpose) + @tube_rack = ::TubeRack.create!(size:, purpose:) Barcode.create!(labware: tube_rack, barcode: barcode, format: barcode_format) diff --git a/app/heron/factories/tube_rack_status.rb b/app/heron/factories/tube_rack_status.rb index d7f1790b15..e70edd093a 100644 --- a/app/heron/factories/tube_rack_status.rb +++ b/app/heron/factories/tube_rack_status.rb @@ -15,9 +15,7 @@ class TubeRackStatus def save return false unless valid? - ActiveRecord::Base.transaction do - @tube_rack_status = ::TubeRackStatus.create!(barcode: barcode, status: status, messages: messages) - end + ActiveRecord::Base.transaction { @tube_rack_status = ::TubeRackStatus.create!(barcode:, status:, messages:) } true end diff --git a/app/models/accessionable/submission.rb b/app/models/accessionable/submission.rb index d3b3defce8..40d17082a3 100644 --- a/app/models/accessionable/submission.rb +++ b/app/models/accessionable/submission.rb @@ -88,7 +88,7 @@ def initialize(user) end def build(markup) - markup.CONTACT(inform_on_error: inform_on_error, inform_on_status: inform_on_status, name: name) + markup.CONTACT(inform_on_error:, inform_on_status:, name:) end end end diff --git a/app/models/aliquot/aliquotable.rb b/app/models/aliquot/aliquotable.rb index a084537dac..ac5b7a1a31 100644 --- a/app/models/aliquot/aliquotable.rb +++ b/app/models/aliquot/aliquotable.rb @@ -22,8 +22,8 @@ def self.included(base) # rubocop:todo Metrics/AbcSize, Metrics/MethodLength end module ClassMethods - def receptacle_alias(name, options = {}, &block) - has_many(name, -> { distinct }, options.merge(through: :aliquots, source: :receptacle), &block) + def receptacle_alias(name, options = {}, &) + has_many(name, -> { distinct }, options.merge(through: :aliquots, source: :receptacle), &) end end end diff --git a/app/models/aliquot/data_for_substitution.rb b/app/models/aliquot/data_for_substitution.rb index 456df0f781..90bb1b2bd4 100644 --- a/app/models/aliquot/data_for_substitution.rb +++ b/app/models/aliquot/data_for_substitution.rb @@ -17,13 +17,13 @@ def generate_substitution_hash def tag_id_substitution return {} if changes[:tag_id].blank? - { original_tag_id: original_tag_id, substitute_tag_id: substitute_tag_id } + { original_tag_id:, substitute_tag_id: } end def tag2_id_substitution return {} if changes[:tag2_id].blank? - { original_tag2_id: original_tag2_id, substitute_tag2_id: substitute_tag2_id } + { original_tag2_id:, substitute_tag2_id: } end def original_tag_id @@ -53,6 +53,6 @@ def changes private def aliquot_identifiers - { sample_id: sample_id, library_id: library_id } + { sample_id:, library_id: } end end diff --git a/app/models/api/base.rb b/app/models/api/base.rb index aed42ede31..a87d4d67cd 100644 --- a/app/models/api/base.rb +++ b/app/models/api/base.rb @@ -173,9 +173,9 @@ def self.default_object end # rubocop:todo Metrics/MethodLength - def self.with_association(association, options = {}, &block) # rubocop:todo Metrics/AbcSize + def self.with_association(association, options = {}, &) # rubocop:todo Metrics/AbcSize association_helper = Class.new(Api::Base) - association_helper.class_eval(&block) + association_helper.class_eval(&) association_helper.singleton_class.class_eval do alias_method(:default_object, options[:if_nil_use]) if options.key?(:if_nil_use) define_method(:lookup_by) { options[:lookup_by] } @@ -192,9 +192,9 @@ def self.with_association(association, options = {}, &block) # rubocop:todo Metr # rubocop:enable Metrics/MethodLength # rubocop:todo Metrics/MethodLength - def self.with_nested_has_many_association(association, options = {}, &block) # rubocop:todo Metrics/AbcSize + def self.with_nested_has_many_association(association, options = {}, &) # rubocop:todo Metrics/AbcSize association_helper = Class.new(Api::Base) - association_helper.class_eval(&block) + association_helper.class_eval(&) association_helper.singleton_class.class_eval do define_method(:association) { association } define_method(:alias) { options[:as] || association } diff --git a/app/models/api/sample_io.rb b/app/models/api/sample_io.rb index f2ec7f4193..feff41cc6e 100644 --- a/app/models/api/sample_io.rb +++ b/app/models/api/sample_io.rb @@ -110,6 +110,6 @@ def json_root # Whenever we create samples through the API we also need to register a sample tube too. The user # can then retrieve the sample tube information through the API. def self.create!(parameters) - super.tap { |sample| Tube::Purpose.standard_sample_tube.create!.aliquots.create!(sample: sample) } + super.tap { |sample| Tube::Purpose.standard_sample_tube.create!.aliquots.create!(sample:) } end end diff --git a/app/models/application_record.rb b/app/models/application_record.rb index 003818045f..1908e01b43 100644 --- a/app/models/application_record.rb +++ b/app/models/application_record.rb @@ -38,7 +38,7 @@ def find_by_id_or_name(id, name) return find(id) if id.present? raise StandardError, 'Must specify at least ID or name' if name.blank? - find_by(name: name) + find_by(name:) end # Temporary compatibility layer following AssetRefactor: diff --git a/app/models/asset_barcode.rb b/app/models/asset_barcode.rb index 18fb5e6301..5bb7be6b32 100644 --- a/app/models/asset_barcode.rb +++ b/app/models/asset_barcode.rb @@ -13,10 +13,10 @@ class AssetBarcode < ApplicationRecord # @note The returned string does NOT include the prefix. # @return [String] The number component of the new barcode in string format. def self.new_barcode(prefix = Tube.default_prefix) - barcode = (AssetBarcode.create!).id + barcode = AssetBarcode.create!.id while Barcode.find_by(barcode: SBCF::SangerBarcode.from_prefix_and_number(prefix, barcode).human_barcode) - barcode = (AssetBarcode.create!).id + barcode = AssetBarcode.create!.id end barcode.to_s diff --git a/app/models/asset_group.rb b/app/models/asset_group.rb index 86d1276b75..6e607f79a4 100644 --- a/app/models/asset_group.rb +++ b/app/models/asset_group.rb @@ -40,9 +40,7 @@ def unaccessioned_samples def self.find_or_create_asset_group(new_assets_name, study) # Is new name set or create group asset_group = nil - if new_assets_name.present? - asset_group = AssetGroup.create_with(study: study).find_or_create_by(name: new_assets_name) - end + asset_group = AssetGroup.create_with(study:).find_or_create_by(name: new_assets_name) if new_assets_name.present? asset_group end diff --git a/app/models/attributable.rb b/app/models/attributable.rb index c68f5799ff..0e78320148 100644 --- a/app/models/attributable.rb +++ b/app/models/attributable.rb @@ -28,8 +28,8 @@ def self.included(base) end end - def attribute_details_for(*args) - self.class.attribute_details_for(*args) + def attribute_details_for(*) + self.class.attribute_details_for(*) end def instance_defaults diff --git a/app/models/bait_library_layout.rb b/app/models/bait_library_layout.rb index 9c435856e8..f76899408b 100644 --- a/app/models/bait_library_layout.rb +++ b/app/models/bait_library_layout.rb @@ -12,29 +12,41 @@ class BaitLibraryLayout < ApplicationRecord validates :plate, presence: true validates :plate_id, uniqueness: true - # The layout of the bait libraries is recorded so that we can see what happened. It is serialized in a compact + # The layout of the bait libraries is recorded so that we can see what happened. It is serialized in a compact # form that maps the bait library to the wells it was put into, but can be accessed in the reverse. serialize :layout, Hash validates_unassigned :layout + # Before creation the layout of the bait libraries on the plate must be performed, based on the information + # specified as part of the submissions that lead to this plate. + before_create :layout_bait_libraries_on_plate + def well_layout {}.tap { |well_to_name| layout.map { |name, locations| locations.map { |l| well_to_name[l] = name } } } end + # This method can be used to get a preview of what will happen when the bait libraries are laid out on a plate. + def self.preview!(attributes = {}, &block) + new(attributes, &block).tap do |layout| + raise ActiveRecord::RecordInvalid, layout unless layout.valid? + + layout.unsaved_uuid! + layout.send(:generate_for_preview) + end + end + + private + # Records the assignment of the bait library to a particular well def record_bait_library_assignment(well, bait_library) # NOTE: The serialization of the hash prevents the use of a block # to set default values etc. (layout[bait_library.name] ||= []).push(well.map.description) end - private :record_bait_library_assignment - # Before creation the layout of the bait libraries on the plate must be performed, based on the information - # specified as part of the submissions that lead to this plate. - before_create :layout_bait_libraries_on_plate def layout_bait_libraries_on_plate # To improve the performance we store the aliquot IDs that need each of the individual bait libraries - # attached to them in a hash. Then we'll be able to bulk update them later. + # attached to them in a hash. Then we'll be able to bulk update them later. bait_libraries_to_aliquot_ids = Hash.new { |h, k| h[k] = [] } each_bait_library_assignment do |well, bait_library| bait_libraries_to_aliquot_ids[bait_library.id].concat(well.aliquot_ids) @@ -43,49 +55,31 @@ def layout_bait_libraries_on_plate # Bulk update the aliquots with the appropriate bait libraries bait_libraries_to_aliquot_ids.each do |bait_library_id, aliquot_ids| - Aliquot.where(id: aliquot_ids).update_all(bait_library_id: bait_library_id) # rubocop:disable Rails/SkipsModelValidations + Aliquot.where(id: aliquot_ids).update_all(bait_library_id:) # rubocop:disable Rails/SkipsModelValidations end end - private :layout_bait_libraries_on_plate - # rubocop:todo Metrics/MethodLength - def each_bait_library_assignment # rubocop:todo Metrics/AbcSize - # We only accept the wells which have been pooled - plate - .wells - .with_pool_id - .filter(&:pool_id) - .each do |well| - bait_library = - well.aliquot_requests.for_submission_id(well.pool_id).map(&:request_metadata).map(&:bait_library).uniq - if bait_library.size > 1 - raise StandardError, - "Multiple bait libraries found for #{well.map.description} on plate #{well.plate.human_barcode}" - end - - yield(well, bait_library.first) - end + def first_bait_library(well) + bait_library = + well.aliquot_requests.for_submission_id(well.pool_id).map(&:request_metadata).map(&:bait_library).uniq + + if bait_library.size > 1 + raise StandardError, + "Multiple bait libraries found for #{well.map.description} on plate #{well.plate.human_barcode}" + end + + bait_library.first end - # rubocop:enable Metrics/MethodLength - private :each_bait_library_assignment + def each_bait_library_assignment + # We only accept the wells which have been pooled + plate.wells.with_pool_id.filter(&:pool_id).each { |well| yield well, first_bait_library(well) } + end - # Generates the layout of bait libraries for preview. In other words, none of the actually assignment is - # done, just the recording, which would fail validation if an attempt was then made to save it. So this is + # Generates the layout of bait libraries for preview. In other words, none of the actual assignment is + # done, just the recording, which would fail validation if an attempt was then made to save it. So this is # safe to do. def generate_for_preview each_bait_library_assignment { |well, bait_library| record_bait_library_assignment(well, bait_library) } end - private :generate_for_preview - - # This method can be used to view a previous of what will happen when the bait libraries are laid out - # on a plate. - def self.preview!(attributes = {}, &block) - new(attributes, &block).tap do |layout| - raise ActiveRecord::RecordInvalid, layout unless layout.valid? - - layout.unsaved_uuid! - layout.send(:generate_for_preview) - end - end end diff --git a/app/models/barcode/format_handlers.rb b/app/models/barcode/format_handlers.rb index 59429e8b1c..3ccaad49a3 100644 --- a/app/models/barcode/format_handlers.rb +++ b/app/models/barcode/format_handlers.rb @@ -172,7 +172,7 @@ class Sequencescape22 < BaseRegExBarcode class Infinium < BaseRegExBarcode # Based on ALL existing examples (bar what appears to be accidental usage of the sanger barcode in 5 cases) # eg. WG0000001-DNA and WG0000001-BCD - self.format = /\A(?WG)(?[0-9]{7})-(?[DNA|BCD]{3})\z/ + self.format = /\A(?WG)(?[0-9]{7})-(?[DNA|BC]{3})\z/ end # Fluidigm barcodes are externally generated barcodes present on fluidigm plates. They are ten digits long. diff --git a/app/models/batch.rb b/app/models/batch.rb index 27e9ba07ae..27a67a1ab3 100644 --- a/app/models/batch.rb +++ b/app/models/batch.rb @@ -586,12 +586,12 @@ def generate_target_assets_for_requests # rubocop:todo Metrics/AbcSize requests_to_update.concat(downstream_requests.map { |r| [r, target_asset.receptacle] }) end - request.update!(target_asset: target_asset) + request.update!(target_asset:) target_asset.parents << request.asset.labware end - requests_to_update.each { |request, asset| request.update!(asset: asset) } + requests_to_update.each { |request, asset| request.update!(asset:) } end # rubocop:enable Metrics/MethodLength end diff --git a/app/models/batch_request.rb b/app/models/batch_request.rb index 53e8148865..c80d7191de 100644 --- a/app/models/batch_request.rb +++ b/app/models/batch_request.rb @@ -12,7 +12,7 @@ class BatchRequest < ApplicationRecord belongs_to :request, inverse_of: :batch_request scope :ordered, -> { order(:position) } - scope :at_position, ->(position) { where(position: position) } + scope :at_position, ->(position) { where(position:) } # Ensure that any requests that are added have a position that is unique and incremental in the batch, # unless we're moving them around in the batch, in which case we assume it'll be valid. diff --git a/app/models/broadcast_event/qc_assay.rb b/app/models/broadcast_event/qc_assay.rb index e9aa752990..edb0b119f5 100644 --- a/app/models/broadcast_event/qc_assay.rb +++ b/app/models/broadcast_event/qc_assay.rb @@ -13,9 +13,7 @@ def self.generate_events(qc_assay) .qc_results .distinct .pluck(:assay_type, :assay_version) - .map do |assay_type, assay_version| - create!(seed: qc_assay, properties: { assay_type: assay_type, assay_version: assay_version }) - end + .map { |assay_type, assay_version| create!(seed: qc_assay, properties: { assay_type:, assay_version: }) } end has_subjects(:sample) { |_qc_assay, event| event.samples } diff --git a/app/models/bulk_submission.rb b/app/models/bulk_submission.rb index 755c184a92..3c8c5fa313 100644 --- a/app/models/bulk_submission.rb +++ b/app/models/bulk_submission.rb @@ -32,6 +32,7 @@ class BulkSubmission # rubocop:todo Metrics/ClassLength extend ActiveModel::Naming include Submission::AssetSubmissionFinder + include Submission::ValidationsByTemplateName attr_accessor :spreadsheet, :encoding @@ -116,11 +117,9 @@ def valid_header? return false if headers.nil? return true if headers.include? 'submission name' - # rubocop:todo Layout/LineLength errors.add :spreadsheet, - "You submitted an incompatible spreadsheet. Please ensure your spreadsheet contains the 'submission name' column" - - # rubocop:enable Layout/LineLength + 'You submitted an incompatible spreadsheet. Please ensure your spreadsheet contains ' \ + "the 'submission name' column" false end @@ -150,6 +149,9 @@ def process # rubocop:todo Metrics/CyclomaticComplexity if spreadsheet_valid? submission_details = submission_structure + # Apply any additional validations based on the submission template name + apply_additional_validations_by_template_name unless errors.count > 0 + raise ActiveRecord::RecordInvalid, self if errors.count > 0 # Within a single transaction process each of the rows of the CSV file as a separate submission. Any name @@ -228,7 +230,9 @@ def process # rubocop:todo Metrics/CyclomaticComplexity 'pre-capture group', 'gigabases expected', 'priority', - 'flowcell type' + 'flowcell type', + 'scrna core number of samples per pool', + 'scrna core cells per chip well' ].freeze ALIAS_FIELDS = { 'plate barcode' => 'barcode', 'tube barcode' => 'barcode' }.freeze @@ -289,16 +293,15 @@ def submission_structure # rubocop:todo Metrics/CyclomaticComplexity # rubocop:enable Metrics/AbcSize, Metrics/MethodLength, Metrics/PerceivedComplexity def shared_options!(rows) # rubocop:todo Metrics/MethodLength - # Builds an array of the common fields. Raises and exception if the fields are inconsistent + # Builds an array of the common fields. Raises an exception if the fields are inconsistent COMMON_FIELDS.map do |field| option = rows.pluck(field).uniq if option.count > 1 provided_values = option.map { |o| "'#{o}'" }.to_sentence errors.add( :spreadsheet, - # rubocop:todo Layout/LineLength - "#{field} should be identical for all requests in asset group '#{rows.first['asset group name']}'. Given values were: #{provided_values}." - # rubocop:enable Layout/LineLength + "#{field} should be identical for all requests in asset group '#{rows.first['asset group name']}'. " \ + "Given values were: #{provided_values}." ) end [field, option.first] @@ -325,7 +328,9 @@ def extract_request_options(details) ['pre-capture plex level', 'pre_capture_plex_level'], ['gigabases expected', 'gigabases_expected'], ['primer panel', 'primer_panel_name'], - ['flowcell type', 'requested_flowcell_type'] + ['flowcell type', 'requested_flowcell_type'], + ['scrna core number of samples per pool', 'number_of_samples_per_pool'], + ['scrna core cells per chip well', 'cells_per_chip_well'] ].each do |source_key, target_key| assign_value_if_source_present(details, source_key, request_options, target_key) end @@ -409,10 +414,9 @@ def prepare_order(details) # rubocop:todo Metrics/CyclomaticComplexity if attributes[:asset_group].nil? attributes[:assets] = found_assets elsif found_assets.present? && found_assets != attributes[:asset_group].assets - # rubocop:todo Layout/LineLength raise StandardError, - "Asset Group '#{attributes[:asset_group].name}' contains different assets to those you specified. You may be reusing an asset group name" - # rubocop:enable Layout/LineLength + "Asset Group '#{attributes[:asset_group].name}' contains different assets to those you specified. " \ + 'You may be reusing an asset group name' end add_study_to_assets(found_assets, study) diff --git a/app/models/cherrypick_request.rb b/app/models/cherrypick_request.rb index 34ae04ca0c..d450d3671b 100644 --- a/app/models/cherrypick_request.rb +++ b/app/models/cherrypick_request.rb @@ -13,7 +13,7 @@ def on_started end def on_passed - target_asset.transfer_requests_as_target.where(submission_id: submission_id).find_each(&:pass!) + target_asset.transfer_requests_as_target.where(submission_id:).find_each(&:pass!) end def reduce_source_volume diff --git a/app/models/cherrypick_task.rb b/app/models/cherrypick_task.rb index 13304cb801..7fb4b9ce50 100644 --- a/app/models/cherrypick_task.rb +++ b/app/models/cherrypick_task.rb @@ -22,12 +22,7 @@ class CherrypickTask < Task # rubocop:todo Metrics/ClassLength # @return [CherrypickTask::ControlLocator] A generator of control locations # def new_control_locator(batch_id, total_wells, num_control_wells, wells_to_leave_free: DEFAULT_WELLS_TO_LEAVE_FREE) - CherrypickTask::ControlLocator.new( - batch_id: batch_id, - total_wells: total_wells, - num_control_wells: num_control_wells, - wells_to_leave_free: wells_to_leave_free - ) + CherrypickTask::ControlLocator.new(batch_id:, total_wells:, num_control_wells:, wells_to_leave_free:) end # diff --git a/app/models/comment.rb b/app/models/comment.rb index 06e2070052..c792088dbc 100644 --- a/app/models/comment.rb +++ b/app/models/comment.rb @@ -36,10 +36,11 @@ def self.counts_for(commentables) def self.counts_for_requests(requests) # rubocop:todo Metrics/AbcSize all_commentables = requests.flat_map { |request| [request, request.asset, request.asset&.labware] } counts = where(commentable: all_commentables.compact).group(:commentable_type, :commentable_id).count + requests.each_with_object({}) do |request, counter_cache| request_count = counts.fetch(['Request', request.id], 0) receptacle_count = counts.fetch(['Receptacle', request.asset_id], 0) - labware_count = counts.fetch(['Labware', request.asset.labware_id], 0) + labware_count = counts.fetch(['Labware', request.asset&.labware_id], 0) counter_cache[request.id] = request_count + receptacle_count + labware_count end end diff --git a/app/models/comments_proxy/base.rb b/app/models/comments_proxy/base.rb index e6ec2cfb6f..e7597bc071 100644 --- a/app/models/comments_proxy/base.rb +++ b/app/models/comments_proxy/base.rb @@ -38,8 +38,8 @@ def comment_assn end # We're using group above, resulting in size and count returning a hash, not a count. - def size(*args) - comment_assn.size(*args).length + def size(*) + comment_assn.size(*).length end def count(*_args) diff --git a/app/models/field_info.rb b/app/models/field_info.rb index 8c1d40891c..b30465b20b 100644 --- a/app/models/field_info.rb +++ b/app/models/field_info.rb @@ -42,7 +42,7 @@ def parameters=(parameters) deprecate :parameters= => 'set selection directly' def parameters - { min: min, max: max, step: step } + { min:, max:, step: } end def value diff --git a/app/models/item.rb b/app/models/item.rb index 0be85c299b..69bb5f5f8e 100644 --- a/app/models/item.rb +++ b/app/models/item.rb @@ -33,7 +33,7 @@ class Item < ApplicationRecord before_validation :set_version, on: :create def set_version - things_with_same_name = self.class.where(name: name) + things_with_same_name = self.class.where(name:) if things_with_same_name.empty? increment(:version) else diff --git a/app/models/lab_event.rb b/app/models/lab_event.rb index 63b57f6f91..9b8fbb5269 100644 --- a/app/models/lab_event.rb +++ b/app/models/lab_event.rb @@ -35,7 +35,7 @@ def descriptor_value_for(name) end def add_new_descriptor(name, value) - add_descriptor Descriptor.new(name: name, value: value) + add_descriptor Descriptor.new(name:, value:) end def generate_broadcast_event diff --git a/app/models/labware.rb b/app/models/labware.rb index e71d5c4cf9..212b5f58a8 100644 --- a/app/models/labware.rb +++ b/app/models/labware.rb @@ -118,7 +118,7 @@ def receptacle_proxy } scope :for_lab_searches_display, lambda { includes(:barcodes, requests_as_source: %i[pipeline batch]).order('requests.pipeline_id ASC') } - scope :named, ->(name) { where(name: name) } + scope :named, ->(name) { where(name:) } scope :with_purpose, ->(*purposes) { where(plate_purpose_id: purposes.flatten) } scope :include_scanned_into_lab_event, -> { includes(:scanned_into_lab_event) } scope :include_creation_batches, -> { includes(:creation_batches) } diff --git a/app/models/labwhere_reception.rb b/app/models/labwhere_reception.rb index f5f6c3593f..7cd04df19e 100644 --- a/app/models/labwhere_reception.rb +++ b/app/models/labwhere_reception.rb @@ -69,13 +69,7 @@ def save # rubocop:todo Metrics/AbcSize assets.each do |asset| asset.events.create_scanned_into_lab!(location_barcode, user.login) - BroadcastEvent::LabwareReceived.create!( - seed: asset, - user: user, - properties: { - location_barcode: location_barcode - } - ) + BroadcastEvent::LabwareReceived.create!(seed: asset, user: user, properties: { location_barcode: }) end valid? diff --git a/app/models/location_report.rb b/app/models/location_report.rb index dc1c8177ec..95c2e7c522 100644 --- a/app/models/location_report.rb +++ b/app/models/location_report.rb @@ -176,14 +176,7 @@ def generate_study_cols_for_row(cur_study) end def search_for_plates_by_selection - params = { - faculty_sponsor_ids: faculty_sponsor_ids, - study_id: study_id, - start_date: start_date, - end_date: end_date, - plate_purpose_ids: plate_purpose_ids, - barcodes: barcodes - } + params = { faculty_sponsor_ids:, study_id:, start_date:, end_date:, plate_purpose_ids:, barcodes: } Plate.search_for_plates(params) end diff --git a/app/models/lot.rb b/app/models/lot.rb index ce79be8410..e6eb025b62 100644 --- a/app/models/lot.rb +++ b/app/models/lot.rb @@ -34,7 +34,7 @@ def self.included(base) scope :include_lot_type, -> { includes(:lot_type) } scope :include_template, -> { includes(:template) } - scope :with_lot_number, ->(lot_number) { where(lot_number: lot_number) } + scope :with_lot_number, ->(lot_number) { where(lot_number:) } scope :with_qc_asset, ->(qc_asset) do diff --git a/app/models/map.rb b/app/models/map.rb index 8248ddc2ce..de6b912a4b 100644 --- a/app/models/map.rb +++ b/app/models/map.rb @@ -99,13 +99,13 @@ def self.plate_length(plate_size) def self.vertical_position_to_description(well_position, length) desc_letter = (((well_position - 1) % length) + 65).chr desc_number = ((well_position - 1) / length) + 1 - (desc_letter + (desc_number.to_s)) + (desc_letter + desc_number.to_s) end def self.horizontal_position_to_description(well_position, width) desc_letter = (((well_position - 1) / width) + 65).chr desc_number = ((well_position - 1) % width) + 1 - (desc_letter + (desc_number.to_s)) + (desc_letter + desc_number.to_s) end def self.horizontal_to_vertical(well_position, plate_size) @@ -147,7 +147,7 @@ def alternate_position(well_position, size, *dimensions) module Sequential def self.location_from_row_and_column(row, column, width, size) digit_count = Math.log10(size + 1).ceil - "S%0#{digit_count}d" % [((row) * width) + column] + "S%0#{digit_count}d" % [(row * width) + column] end def self.location_from_index(index, size) diff --git a/app/models/messenger_creator.rb b/app/models/messenger_creator.rb index 2c279fb5c2..a1532eabfb 100644 --- a/app/models/messenger_creator.rb +++ b/app/models/messenger_creator.rb @@ -31,7 +31,7 @@ def each_target validate :template_exists? def create!(base) - finder.new(base).each_target { |target| Messenger.create!(target: target, root: root, template: template) } + finder.new(base).each_target { |target| Messenger.create!(target:, root:, template:) } end private diff --git a/app/models/metadata.rb b/app/models/metadata.rb index aa925c3289..0c5010f150 100644 --- a/app/models/metadata.rb +++ b/app/models/metadata.rb @@ -4,10 +4,10 @@ module Metadata # @!macro [attach] has_metadata # @!parse class Metadata < Metadata::Base; end - def has_metadata(options = {}, &block) + def has_metadata(options = {}, &) as_class = options.delete(:as) || self table_name = options.delete(:table_name) || "#{as_class.name.demodulize.underscore}_metadata" - construct_metadata_class(table_name, as_class, &block) + construct_metadata_class(table_name, as_class, &) build_association(as_class, options) end @@ -88,9 +88,9 @@ def for?(service) end end - def construct_metadata_class(table_name, as_class, &block) + def construct_metadata_class(table_name, as_class, &) parent_class = self == as_class ? Metadata::Base : as_class::Metadata - metadata = Class.new(parent_class, &block) + metadata = Class.new(parent_class, &) as_name = as_class.name.demodulize.underscore @@ -117,8 +117,8 @@ class Base < ApplicationRecord # This ensures that the default values are stored within the DB, meaning that this information will be # preserved for the future, unlike the original properties information which didn't store values when # nil which lead to us having to guess. - def initialize(attributes = {}, *args, &block) - super(self.class.defaults.merge(attributes.try(:symbolize_keys) || {}), *args, &block) + def initialize(attributes = {}, *, &) + super(self.class.defaults.merge(attributes.try(:symbolize_keys) || {}), *, &) end before_validation :merge_instance_defaults, on: :create diff --git a/app/models/metadata/builder_base.rb b/app/models/metadata/builder_base.rb index bc91d984ea..e9bd2618b0 100644 --- a/app/models/metadata/builder_base.rb +++ b/app/models/metadata/builder_base.rb @@ -2,13 +2,13 @@ class Metadata::BuilderBase < ActionView::Helpers::FormBuilder attr_writer :locals - def initialize(*args, &block) + def initialize(*args, &) super @views, @locals, @root = {}, {}, nil end - def view_for(type, partial_name = nil, &block) - @views[type.to_sym] = partial_name.nil? ? { inline: capture(&block) } : { partial: partial_name } + def view_for(type, partial_name = nil, &) + @views[type.to_sym] = partial_name.nil? ? { inline: capture(&) } : { partial: partial_name } end private @@ -41,6 +41,6 @@ def render_view(type, field, options = {}) ) locals[:group] = options[:grouping].downcase.gsub(/[^a-z0-9]+/, '_') if options[:grouping].present? locals = yield(locals) if block_given? - render(view.merge(locals: locals)) + render(view.merge(locals:)) end end diff --git a/app/models/metadata/form_builder.rb b/app/models/metadata/form_builder.rb index b6c19c8459..8e41e21b47 100644 --- a/app/models/metadata/form_builder.rb +++ b/app/models/metadata/form_builder.rb @@ -1,6 +1,6 @@ # frozen_string_literal: true class Metadata::FormBuilder < Metadata::BuilderBase - def initialize(*args, &block) + def initialize(*args, &) super view_for(:field, 'shared/metadata/edit_field') view_for(:radio_field, 'shared/metadata/radio_field') @@ -104,14 +104,14 @@ def header(field, options = {}) # You can use `:to` to give the name of the field, `:when` for the single value when the fields should # be shown, and `:in` for a group of values. You *must* call finalize_related_fields at the end of # your view to get the appropriate behaviour - def related_fields(options, &block) # rubocop:todo Metrics/AbcSize + def related_fields(options, &) # rubocop:todo Metrics/AbcSize options.symbolize_keys! values = (options.fetch(:in, Array(options[:when])) - Array(options[:not])).map do |v| v.to_s.downcase.gsub(/[^a-z0-9]+/, '_') end - content = capture(&block) + content = capture(&) concat(tag.div(content, class: [:related_to, options[:to], values].flatten.join(' '))) @related_fields.push(options[:to]) diff --git a/app/models/metadata/view_builder.rb b/app/models/metadata/view_builder.rb index e9b5861ff8..e7de07ca1f 100644 --- a/app/models/metadata/view_builder.rb +++ b/app/models/metadata/view_builder.rb @@ -1,6 +1,6 @@ # frozen_string_literal: true class Metadata::ViewBuilder < Metadata::BuilderBase - def initialize(*args, &block) + def initialize(*args, &) super view_for(:plain_value, 'shared/metadata/plain_field') view_for(:file, 'shared/metadata/file') diff --git a/app/models/order.rb b/app/models/order.rb index f584aef0f9..518a85940d 100644 --- a/app/models/order.rb +++ b/app/models/order.rb @@ -198,9 +198,9 @@ def duplicates_within(timespan) # rubocop:todo Metrics/AbcSize, Metrics/MethodLe matching_orders = Order .containing_samples(all_samples) - .where(template_name: template_name) + .where(template_name:) .includes(:submission, assets: :samples) - .where.not(orders: { id: id }) + .where.not(orders: { id: }) .where('orders.created_at > ?', Time.current - timespan) return false if matching_orders.empty? diff --git a/app/models/parsers.rb b/app/models/parsers.rb index 0c9ba40335..dc8637f45c 100644 --- a/app/models/parsers.rb +++ b/app/models/parsers.rb @@ -4,7 +4,7 @@ module Parsers ENCODINGS = %w[Windows-1252 iso-8859-1 utf-8 utf-16].freeze - PARSERS = [QuantParser, BioanalysisCsvParser, PlateReaderParser, CardinalPbmcCountParser].freeze + PARSERS = [QuantParser, BioanalysisCsvParser, PlateReaderParser, PbmcCountParser].freeze def self.parser_for(filename, content_type, content) return nil unless filename.downcase.end_with?('.csv') || content_type == 'text/csv' diff --git a/app/models/parsers/bioanalysis_csv_parser.rb b/app/models/parsers/bioanalysis_csv_parser.rb index 33cbe25434..62c06f473e 100644 --- a/app/models/parsers/bioanalysis_csv_parser.rb +++ b/app/models/parsers/bioanalysis_csv_parser.rb @@ -42,7 +42,7 @@ def table_content_hash(group) # rubocop:todo Metrics/AbcSize end def build_range(range) - range = range == nil ? [0, content.length - 1] : range.dup + range = range.nil? ? [0, content.length - 1] : range.dup range.push(content.length - 1) if (range.length == 1) range end @@ -63,7 +63,7 @@ def get_groups(regexp, range = nil) # rubocop:todo Metrics/CyclomaticComplexity group_contents.each_with_index do |line, pos| if line[0].present? && line[0].match(regexp) && group.empty? group.push(pos) - elsif (line.empty? && group.one?) + elsif line.empty? && group.one? group.push(pos - 1) end @@ -71,7 +71,7 @@ def get_groups(regexp, range = nil) # rubocop:todo Metrics/CyclomaticComplexity groups.push [group[0] + range[0], group[1] + range[0]] group = [] end - groups.push [group[0] + range[0], pos + range[0]] if ((group.length == 1) && (pos == (group_contents.length - 1))) + groups.push [group[0] + range[0], pos + range[0]] if (group.length == 1) && (pos == (group_contents.length - 1)) end groups end @@ -115,7 +115,7 @@ def parse_samples groups .each_with_index .map do |group, pos| - next_index = (pos == (groups.length - 1)) ? @content.length - 1 : groups[pos + 1][0] - 1 + next_index = pos == (groups.length - 1) ? @content.length - 1 : groups[pos + 1][0] - 1 [group[0], next_index] end .reduce({}) { |memo, group| memo.merge(parse_sample group) } diff --git a/app/models/parsers/cardinal_pbmc_count_parser.rb b/app/models/parsers/pbmc_count_parser.rb similarity index 82% rename from app/models/parsers/cardinal_pbmc_count_parser.rb rename to app/models/parsers/pbmc_count_parser.rb index c6489be771..ccfb223aa1 100644 --- a/app/models/parsers/cardinal_pbmc_count_parser.rb +++ b/app/models/parsers/pbmc_count_parser.rb @@ -1,7 +1,7 @@ # frozen_string_literal: true module Parsers - # A parser for the cardinal pipeline qc file - class CardinalPbmcCountParser + # A parser for the cardinal and scrna pipeline qc files + class PbmcCountParser class_attribute :assay_type, :assay_version HEADERS = [ @@ -20,7 +20,7 @@ class CardinalPbmcCountParser 'Errors:' ].freeze - self.assay_type = 'Cardinal_PBMC_Count' + self.assay_type = 'PBMC_Count' self.assay_version = 'v1.0' def self.parses?(content) @@ -38,8 +38,9 @@ def rows end # 0 - well name - # 2 - cell count + # 2 - live cell count # 4 - viability + # 9 - total cell count def qc_data @qc_data ||= {}.tap do |qc_data| @@ -60,13 +61,14 @@ def get_well_location(cell) cell.split(':')[1] end - def each_well_and_parameters(&block) - qc_data.each(&block) + def each_well_and_parameters(&) + qc_data.each(&) end def qc_metrics_hash(row) {}.tap do |hash| hash[:live_cell_count] = Unit.new(row[2], 'cells') + hash[:total_cell_count] = Unit.new(row[9], 'cells') viability = row[4] hash[:viability] = Unit.new(viability) unless viability == 'NaN' end diff --git a/app/models/pbmc_pooling_customer_request.rb b/app/models/pbmc_pooling_customer_request.rb new file mode 100644 index 0000000000..b98639e7e1 --- /dev/null +++ b/app/models/pbmc_pooling_customer_request.rb @@ -0,0 +1,9 @@ +# frozen_string_literal: true + +# A class for customer requests that need the extra metadata fields used for PBMC pooling calculations +class PbmcPoolingCustomerRequest < CustomerRequest + has_metadata as: Request do + custom_attribute(:number_of_samples_per_pool, integer: true, required: false, default: nil) + custom_attribute(:cells_per_chip_well, integer: true, required: false, default: nil) + end +end diff --git a/app/models/phi_x.rb b/app/models/phi_x.rb index 32046524f7..d99191a684 100644 --- a/app/models/phi_x.rb +++ b/app/models/phi_x.rb @@ -110,7 +110,7 @@ def self.default_study_option # # @return [String] The named tag option. def self.tag_option_for(i7_oligo:, i5_oligo:) - tag_options.deep_symbolize_keys.key(i7_oligo: i7_oligo, i5_oligo: i5_oligo)&.to_s || + tag_options.deep_symbolize_keys.key(i7_oligo:, i5_oligo:)&.to_s || "UNKNOWN i7:#{i7_oligo || '-'} i5:#{i5_oligo || '-'}" end @@ -124,6 +124,6 @@ def self.find_tag(tag_option, tag_type) oligo = tag_options.dig(tag_option.to_sym, tag_type) return nil if oligo.nil? - tag_group.tags.create_with(map_id: configuration[:tag_map_id]).find_or_create_by!(oligo: oligo) + tag_group.tags.create_with(map_id: configuration[:tag_map_id]).find_or_create_by!(oligo:) end end diff --git a/app/models/phi_x/spiked_buffer.rb b/app/models/phi_x/spiked_buffer.rb index 80604de92c..1ffe84e786 100644 --- a/app/models/phi_x/spiked_buffer.rb +++ b/app/models/phi_x/spiked_buffer.rb @@ -76,7 +76,7 @@ def parent_contains_phi_x def tags i7_oligo, i5_oligo = parent.aliquots.first.tags_combination - PhiX.tag_option_for(i7_oligo: i7_oligo, i5_oligo: i5_oligo) + PhiX.tag_option_for(i7_oligo:, i5_oligo:) end private @@ -89,7 +89,7 @@ def phi_x_sample # due to concerns that it will be set accidentally # But the option is here in the model to set it via study_id if needed in future def aliquot_attributes - study_id.present? ? { study_id: study_id } : {} + study_id.present? ? { study_id: } : {} end # Generates .number PhiX.stock_purpose tubes names diff --git a/app/models/pick_list.rb b/app/models/pick_list.rb index b75994e132..53f01fc8cf 100644 --- a/app/models/pick_list.rb +++ b/app/models/pick_list.rb @@ -91,7 +91,7 @@ def queue_processing # Its listed as a private method, as it is intended as an implementation # detail, and I'm hoping that we'll be able to remove the need for it. def submission - super || build_submission(user: user) + super || build_submission(user:) end def request_type diff --git a/app/models/pick_list/pick.rb b/app/models/pick_list/pick.rb index 5be067e87d..1f5764501c 100644 --- a/app/models/pick_list/pick.rb +++ b/app/models/pick_list/pick.rb @@ -12,7 +12,7 @@ class PickList::Pick # Used to help group compatible picks together into orders def order_options - { study: study, project: project } + { study:, project: } end def study diff --git a/app/models/plate.rb b/app/models/plate.rb index 0655990c19..79bc9c6530 100644 --- a/app/models/plate.rb +++ b/app/models/plate.rb @@ -188,7 +188,7 @@ def submissions def iteration iter = siblings # assets sharing the same parent - .where(plate_purpose_id: plate_purpose_id, sti_type: sti_type) # of the same purpose and type + .where(plate_purpose_id:, sti_type:) # of the same purpose and type .where("#{self.class.table_name}.created_at <= ?", created_at) # created before or at the same time .count(:id) # count the siblings. @@ -336,10 +336,10 @@ def stock_plate end deprecate stock_plate: 'Stock plate is nebulous and can easily lead to unexpected behaviour' - def self.create_with_barcode!(*args, &block) + def self.create_with_barcode!(*args, &) attributes = args.extract_options! attributes[:sanger_barcode] ||= PlateBarcode.create_barcode - create!(attributes, &block) + create!(attributes, &) end def number_of_blank_samples diff --git a/app/models/plate/creator.rb b/app/models/plate/creator.rb index dce665ba56..f363f98f5f 100644 --- a/app/models/plate/creator.rb +++ b/app/models/plate/creator.rb @@ -239,7 +239,7 @@ def create_plates(source_plate_barcodes, current_user, creator_parameters = nil) # rubocop:enable Metrics/MethodLength def add_created_plates(source, destinations) - created_plates.push(source: source, destinations: destinations) + created_plates.push(source:, destinations:) end # rubocop:todo Metrics/MethodLength diff --git a/app/models/plate/creator_parameters.rb b/app/models/plate/creator_parameters.rb index 17c48bb544..3bde66a60b 100644 --- a/app/models/plate/creator_parameters.rb +++ b/app/models/plate/creator_parameters.rb @@ -22,7 +22,7 @@ def plate_dilution_factor(plate) end def params_has_dilution_factor?(params) - (!params[:dilution_factor].nil?) && (!params[:dilution_factor].to_s.empty?) + !params[:dilution_factor].nil? && !params[:dilution_factor].to_s.empty? end def plate_parameters(_plate, parent_plate = nil) # rubocop:todo Metrics/MethodLength diff --git a/app/models/plate/quad_creator.rb b/app/models/plate/quad_creator.rb index 46dc85f7af..2e0b899270 100644 --- a/app/models/plate/quad_creator.rb +++ b/app/models/plate/quad_creator.rb @@ -38,7 +38,7 @@ def target_purpose_id private - def all_parents_acceptable # rubocop:todo Metrics/MethodLength + def all_parents_acceptable @parents.each do |location, parent| case parent when Plate, TubeRack @@ -71,8 +71,7 @@ def creation end def transfer_request_collection - @transfer_request_collection ||= - TransferRequestCollection.new(user: user, transfer_requests_attributes: transfer_requests_attributes) + @transfer_request_collection ||= TransferRequestCollection.new(user:, transfer_requests_attributes:) end def transfer_requests_attributes diff --git a/app/models/plate/sample_tube_factory.rb b/app/models/plate/sample_tube_factory.rb index 34318d9b96..57ff2afeb1 100644 --- a/app/models/plate/sample_tube_factory.rb +++ b/app/models/plate/sample_tube_factory.rb @@ -14,8 +14,7 @@ def create_child_sample_tube(well) def create_sample_tubes_and_print_barcodes(barcode_printer) sample_tubes = create_sample_tubes - print_job = - LabelPrinter::PrintJob.new(barcode_printer.name, LabelPrinter::Label::PlateToTubes, sample_tubes: sample_tubes) + print_job = LabelPrinter::PrintJob.new(barcode_printer.name, LabelPrinter::Label::PlateToTubes, sample_tubes:) print_job.execute sample_tubes diff --git a/app/models/plate_barcode.rb b/app/models/plate_barcode.rb index 6aa1a8e7cd..ae78803b73 100644 --- a/app/models/plate_barcode.rb +++ b/app/models/plate_barcode.rb @@ -25,7 +25,7 @@ def self.create_barcode # Returns: # - Barcode instance, using Sequencescape22 format def self.create_barcode_with_text(text) - response = fetch_response("#{site}/barcodes/#{prefix}/new", { text: text }) + response = fetch_response("#{site}/barcodes/#{prefix}/new", { text: }) Barcode.build_sequencescape22(response) end @@ -37,7 +37,7 @@ def self.create_barcode_with_text(text) # - Barcode instance, using Sequencescape22 format def self.create_child_barcodes(parent_barcode, count = 1) response = fetch_response("#{site}/child-barcodes/#{prefix}/new", { barcode: parent_barcode, count: count }) - response[:barcodes_group][:barcodes].map! { |barcode| Barcode.build_sequencescape22(barcode: barcode) } + response[:barcodes_group][:barcodes].map! { |barcode| Barcode.build_sequencescape22(barcode:) } end # Obtain a record from Baracoda and retries the specified amount of time. If the number or retries is reached diff --git a/app/models/plate_creation.rb b/app/models/plate_creation.rb index 84cd06da7e..70b86ed327 100644 --- a/app/models/plate_creation.rb +++ b/app/models/plate_creation.rb @@ -6,7 +6,7 @@ class PlateCreation < AssetCreation # This is the child that is created from the parent. It cannot be assigned before validation. belongs_to :parent, class_name: 'Plate' - attr_accessor :barcode + attr_accessor :sanger_barcode def record_creation_of_children parent.events.create_plate!(child_purpose, child, user) @@ -34,7 +34,7 @@ def children private :children def create_children! - self.child = child_purpose.create!(barcode: barcode) + self.child = child_purpose.create!(sanger_barcode:) end private :create_children! end diff --git a/app/models/pooled_plate_creation.rb b/app/models/pooled_plate_creation.rb index dc6f4e4001..9ddb938606 100644 --- a/app/models/pooled_plate_creation.rb +++ b/app/models/pooled_plate_creation.rb @@ -2,7 +2,7 @@ # Creating an instance of this class causes a child plate, with the specified plate type, to be created from # the parent. class PooledPlateCreation < AssetCreation - attr_accessor :barcode + attr_accessor :sanger_barcode has_many :parent_associations, foreign_key: 'asset_creation_id', class_name: 'AssetCreation::ParentAssociation' diff --git a/app/models/presenters/batch_submenu_presenter.rb b/app/models/presenters/batch_submenu_presenter.rb index 7af5a00e98..f79b8dec89 100644 --- a/app/models/presenters/batch_submenu_presenter.rb +++ b/app/models/presenters/batch_submenu_presenter.rb @@ -40,9 +40,9 @@ def add_submenu_option(text, action_params) @options += [{ label: text, url: action_params }] end - def each_option(&block) + def each_option(&) build_submenu if @options.nil? - @options.each(&block) + @options.each(&) end private diff --git a/app/models/product_criteria.rb b/app/models/product_criteria.rb index e97d571414..0ea9459fe8 100644 --- a/app/models/product_criteria.rb +++ b/app/models/product_criteria.rb @@ -19,7 +19,7 @@ class ProductCriteria < ApplicationRecord serialize :configuration - scope :for_stage, ->(stage) { where(stage: stage) } + scope :for_stage, ->(stage) { where(stage:) } scope :stock, -> { where(stage: STAGE_STOCK) } scope :older_than, ->(id) { where(['id < ?', id]) } diff --git a/app/models/project.rb b/app/models/project.rb index bb738822dd..8d09b27959 100644 --- a/app/models/project.rb +++ b/app/models/project.rb @@ -61,7 +61,7 @@ def self.states # Allow us to pass in nil or '' if we don't want to filter state. # State is required so we don't need to look up an actual null state - scope :in_state, ->(state) { state.present? ? where(state: state) : all } + scope :in_state, ->(state) { state.present? ? where(state:) : all } scope :approved, -> { where(approved: true) } scope :unapproved, -> { where(approved: false) } diff --git a/app/models/purpose.rb b/app/models/purpose.rb index e9150f1aeb..19ca280e42 100644 --- a/app/models/purpose.rb +++ b/app/models/purpose.rb @@ -85,7 +85,7 @@ def target_class end def prefix=(prefix) - self.barcode_prefix = BarcodePrefix.find_or_create_by(prefix: prefix) + self.barcode_prefix = BarcodePrefix.find_or_create_by(prefix:) end def set_default_barcode_prefix diff --git a/app/models/qc_report.rb b/app/models/qc_report.rb index d1121af7ce..3093e7b6a7 100644 --- a/app/models/qc_report.rb +++ b/app/models/qc_report.rb @@ -82,39 +82,37 @@ module ReportBehaviour # You can trigger a synchronous report manually by calling #generate! # rubocop:todo Metrics/MethodLength def generate_report # rubocop:todo Metrics/AbcSize - begin - study.each_well_for_qc_report_in_batches( - exclude_existing, - product_criteria, - (plate_purposes.empty? ? nil : plate_purposes) - ) do |assets| - # If there are some wells of interest, we get them in a list - connected_wells = Well.hash_stock_with_targets(assets, product_criteria.target_plate_purposes) - - # This transaction is inside the block as otherwise large reports experience issues - # with high memory usage. In the event that an exception is raised the most - # recent set of decisions will be rolled back, and the report will be re-queued. - # The rescue event clears out the remaining metrics, this avoids the risk of duplicate - # metric on complete reports (Although wont help if, say, the database connection fails) - ActiveRecord::Base.transaction do - assets.each do |asset| - criteria = product_criteria.assess(asset, connected_wells[asset.id]) - QcMetric.create!( - asset: asset, - qc_decision: criteria.qc_decision, - metrics: criteria.metrics, - qc_report: self - ) - end + study.each_well_for_qc_report_in_batches( + exclude_existing, + product_criteria, + (plate_purposes.empty? ? nil : plate_purposes) + ) do |assets| + # If there are some wells of interest, we get them in a list + connected_wells = Well.hash_stock_with_targets(assets, product_criteria.target_plate_purposes) + + # This transaction is inside the block as otherwise large reports experience issues + # with high memory usage. In the event that an exception is raised the most + # recent set of decisions will be rolled back, and the report will be re-queued. + # The rescue event clears out the remaining metrics, this avoids the risk of duplicate + # metric on complete reports (Although wont help if, say, the database connection fails) + ActiveRecord::Base.transaction do + assets.each do |asset| + criteria = product_criteria.assess(asset, connected_wells[asset.id]) + QcMetric.create!( + asset: asset, + qc_decision: criteria.qc_decision, + metrics: criteria.metrics, + qc_report: self + ) end end - generation_complete! - rescue => e - # If something goes wrong, requeue the report and re-raise the exception - qc_metrics.clear - requeue! - raise e end + generation_complete! + rescue => e + # If something goes wrong, requeue the report and re-raise the exception + qc_metrics.clear + requeue! + raise e end # rubocop:enable Metrics/MethodLength diff --git a/app/models/qc_report/file.rb b/app/models/qc_report/file.rb index 93d9b0f739..c5a981de6e 100644 --- a/app/models/qc_report/file.rb +++ b/app/models/qc_report/file.rb @@ -65,7 +65,7 @@ def valid? # rubocop:todo Metrics/MethodLength # The report to which the file corresponds def qc_report - @qc_report ||= QcReport.find_by(report_identifier: report_identifier) + @qc_report ||= QcReport.find_by(report_identifier:) end # A hash of the header section @@ -134,7 +134,7 @@ def process_group(group) # rubocop:todo Metrics/AbcSize def process_line(line) qc_decision = (line[:qc_decision] || '').strip proceed = (line[:proceed] || '').strip - { qc_decision: qc_decision, proceed: proceed } + { qc_decision:, proceed: } end def invalid(message) diff --git a/app/models/qc_result.rb b/app/models/qc_result.rb index 2522bd113c..306ce1b388 100644 --- a/app/models/qc_result.rb +++ b/app/models/qc_result.rb @@ -28,7 +28,7 @@ class QcResult < ApplicationRecord validates :key, :value, :units, presence: true - scope :last_qc_result_for, ->(key) { where(key: key).order(created_at: :desc, id: :desc).limit(1) } + scope :last_qc_result_for, ->(key) { where(key:).order(created_at: :desc, id: :desc).limit(1) } scope :order_by_date, -> { order(created_at: :desc) } def self.by_key diff --git a/app/models/qc_result_factory.rb b/app/models/qc_result_factory.rb index d0c2a2632e..bfcddfcbe8 100644 --- a/app/models/qc_result_factory.rb +++ b/app/models/qc_result_factory.rb @@ -23,11 +23,11 @@ def resources end def qc_assay - @qc_assay ||= QcAssay.new(lot_number: lot_number) + @qc_assay ||= QcAssay.new(lot_number:) end def build_resources(assets) - assets.each { |asset| resources << Resource.new(asset.merge(qc_assay: qc_assay)) } + assets.each { |asset| resources << Resource.new(asset.merge(qc_assay:)) } end def except_blank_wells @@ -59,21 +59,11 @@ def initialize(attributes = {}) super(attributes) @asset = build_asset - @qc_result = - QcResult.new( - asset: asset, - key: key, - value: value, - units: units, - cv: cv, - assay_type: assay_type, - assay_version: assay_version, - qc_assay: qc_assay - ) + @qc_result = QcResult.new(asset:, key:, value:, units:, cv:, assay_type:, assay_version:, qc_assay:) end def message_id - "Asset identifier - #{(asset_identifier || 'blank')}" + "Asset identifier - #{asset_identifier || 'blank'}" end def parent_plate diff --git a/app/models/qcable/statemachine.rb b/app/models/qcable/statemachine.rb index 5f47700c66..791f9cd6d9 100644 --- a/app/models/qcable/statemachine.rb +++ b/app/models/qcable/statemachine.rb @@ -47,7 +47,7 @@ def self.included(base) # rubocop:todo Metrics/AbcSize, Metrics/MethodLength end # new version of combinable named_scope - scope :for_state, ->(state) { where(state: state) } + scope :for_state, ->(state) { where(state:) } scope :unavailable, -> { where(state: %i[created pending failed passed destroyed qc_in_progress exhausted]) } end diff --git a/app/models/receptacle.rb b/app/models/receptacle.rb index 6f542bbef4..5298cc1e58 100644 --- a/app/models/receptacle.rb +++ b/app/models/receptacle.rb @@ -51,7 +51,7 @@ class Receptacle < Asset # rubocop:todo Metrics/ClassLength # to a barcode type and retire this delegate :two_dimensional_barcode, :two_dimensional_barcode=, to: :labware, allow_nil: true - scope :named, ->(name) { joins(:labware).where(labware: { name: name }) } + scope :named, ->(name) { joins(:labware).where(labware: { name: }) } # We accept not only an individual barcode but also an array of them. scope :with_barcode, @@ -254,13 +254,13 @@ def library_types def set_as_library(force: false) aliquots.each do |aliquot| - aliquot.set_library(force: force) + aliquot.set_library(force:) aliquot.save! end end def outer_request(submission_id) - transfer_requests_as_target.find_by(submission_id: submission_id).try(:outer_request) + transfer_requests_as_target.find_by(submission_id:).try(:outer_request) end # All studies related to this asset @@ -269,7 +269,7 @@ def related_studies end def attach_tag(tag, tag2 = nil) - tags = { tag: tag, tag2: tag2 }.compact + tags = { tag:, tag2: }.compact return if tags.empty? raise StandardError, 'Cannot tag an empty asset' if aliquots.empty? diff --git a/app/models/request.rb b/app/models/request.rb index b5e3cff493..76f86a6117 100644 --- a/app/models/request.rb +++ b/app/models/request.rb @@ -342,7 +342,7 @@ def self.for_study(study) end def self.number_expected_for_submission_id_and_request_type_id(submission_id, request_type_id) - Request.where(submission_id: submission_id, request_type_id: request_type_id) + Request.where(submission_id:, request_type_id:) end def self.accessioning_required? @@ -366,13 +366,13 @@ def current_request_event end def project_id=(project_id) - raise RuntimeError, 'Initial project already set' if initial_project_id + raise 'Initial project already set' if initial_project_id self.initial_project_id = project_id end def submission_plate_count - submission.requests.where(request_type_id: request_type_id).joins(:source_labware).distinct.count('labware.id') + submission.requests.where(request_type_id:).joins(:source_labware).distinct.count('labware.id') end def update_responsibilities! @@ -386,7 +386,7 @@ def project=(project) end def study_id=(study_id) - raise RuntimeError, 'Initial study already set' if initial_study_id + raise 'Initial study already set' if initial_study_id self.initial_study_id = study_id end @@ -517,7 +517,7 @@ def cancelable? def update_priority priority = (self.priority + 1) % 4 - submission.update!(priority: priority) + submission.update!(priority:) end def priority diff --git a/app/models/request/change_decision.rb b/app/models/request/change_decision.rb index 2ad3a401ce..f8f039553c 100644 --- a/app/models/request/change_decision.rb +++ b/app/models/request/change_decision.rb @@ -57,15 +57,13 @@ def execute! private def perform_decision_change! - begin - ActiveRecord::Base.transaction do - perform_decision_change_request_state! if state_change? - perform_decision_change_asset_qc_state! unless asset_qc_state_absent? - end - rescue ActiveRecord::RecordInvalid => e - reload_objects - raise InvalidDecision, self + ActiveRecord::Base.transaction do + perform_decision_change_request_state! if state_change? + perform_decision_change_asset_qc_state! unless asset_qc_state_absent? end + rescue ActiveRecord::RecordInvalid => e + reload_objects + raise InvalidDecision, self end def reload_objects diff --git a/app/models/request/statemachine.rb b/app/models/request/statemachine.rb index 1273faa86d..e3281601fa 100644 --- a/app/models/request/statemachine.rb +++ b/app/models/request/statemachine.rb @@ -130,7 +130,7 @@ def destroy_aasm # rubocop:todo Metrics/MethodLength end end - scope :for_state, ->(state) { where(state: state) } + scope :for_state, ->(state) { where(state:) } scope :completed, -> { where(state: COMPLETED_STATE) } scope :pending, -> { where(state: %w[pending blocked]) } # block is a kind of substate of pending } diff --git a/app/models/request_type.rb b/app/models/request_type.rb index e81108dfc7..659597d926 100644 --- a/app/models/request_type.rb +++ b/app/models/request_type.rb @@ -112,16 +112,16 @@ def construct_request(construct_method, attributes, klass = request_class) new_request end - def create!(attributes = {}, &block) - construct_request(:create!, attributes, &block) + def create!(attributes = {}, &) + construct_request(:create!, attributes, &) end - def new(attributes = {}, &block) - construct_request(:new, attributes, &block) + def new(attributes = {}, &) + construct_request(:new, attributes, &) end - def create_control!(attributes = {}, &block) - construct_request(:create!, attributes, ControlRequest, &block) + def create_control!(attributes = {}, &) + construct_request(:create!, attributes, ControlRequest, &) end def self.create_asset @@ -172,14 +172,14 @@ def extract_metadata_from_hash(request_options) attributes.delete_if { |k, _| common_attributes.exclude?(k) } end - def create_target_asset!(&block) + def create_target_asset!(&) case when target_purpose.present? - target_purpose.create!(&block).receptacle + target_purpose.create!(&).receptacle when target_asset_type.blank? nil else - target_asset_type.constantize.create!(&block) + target_asset_type.constantize.create!(&) end end diff --git a/app/models/robot.rb b/app/models/robot.rb index 5d8d96c4cb..1e86b62be2 100644 --- a/app/models/robot.rb +++ b/app/models/robot.rb @@ -60,9 +60,9 @@ def generation_behaviour end def generator(batch:, plate_barcode:, pick_number:) - picking_data = Robot::PickData.new(batch, max_beds: max_beds).picking_data_hash(plate_barcode)[pick_number] + picking_data = Robot::PickData.new(batch, max_beds:).picking_data_hash(plate_barcode)[pick_number] layout = verification_behaviour.layout_data_object(picking_data) - generation_behaviour.new(batch: batch, plate_barcode: plate_barcode, picking_data: picking_data, layout: layout) + generation_behaviour.new(batch:, plate_barcode:, picking_data:, layout:) end def self.default_for_verification diff --git a/app/models/robot/verification/base.rb b/app/models/robot/verification/base.rb index b541cff3c2..86a3f229f3 100644 --- a/app/models/robot/verification/base.rb +++ b/app/models/robot/verification/base.rb @@ -220,6 +220,6 @@ def valid_plates_on_robot?(beds, plates, bed_prefix, robot, _batch, expected_pla def cached_pick_data(batch, max_beds) @cached_pick_data ||= {} - @cached_pick_data[[batch, max_beds]] ||= Robot::PickData.new(batch, max_beds: max_beds) + @cached_pick_data[[batch, max_beds]] ||= Robot::PickData.new(batch, max_beds:) end end diff --git a/app/models/role.rb b/app/models/role.rb index 23fe1c4c79..c9450e5440 100644 --- a/app/models/role.rb +++ b/app/models/role.rb @@ -12,8 +12,8 @@ class Role < ApplicationRecord validates :name, presence: true scope :general_roles, -> { where(authorizable_type: nil) } - scope :named, ->(name) { where(name: name) } - scope :authorizing, ->(authorizable) { where(authorizable: authorizable) if authorizable } + scope :named, ->(name) { where(name:) } + scope :authorizing, ->(authorizable) { where(authorizable:) if authorizable } after_destroy :touch_authorizable diff --git a/app/models/sample_manifest/core_behaviour.rb b/app/models/sample_manifest/core_behaviour.rb index 835edf32e5..7513cee410 100644 --- a/app/models/sample_manifest/core_behaviour.rb +++ b/app/models/sample_manifest/core_behaviour.rb @@ -27,8 +27,8 @@ def generate_sanger_ids(count = 1) Array.new(count) { SangerSampleId::Factory.instance.next! } end - def details(&block) - details_array.each(&block) + def details(&) + details_array.each(&) end end @@ -44,7 +44,7 @@ def generate_sample_and_aliquot(sanger_sample_id, receptacle) create_sample(sanger_sample_id).tap do |sample| tag_depth = tag_depth_for_sample(@manifest.pools, receptacle, sanger_sample_id) - receptacle.aliquots.create!(sample: sample, study: study, tag_depth: tag_depth) + receptacle.aliquots.create!(sample:, study:, tag_depth:) study.samples << sample end diff --git a/app/models/sample_manifest/generator.rb b/app/models/sample_manifest/generator.rb index e62e1edb24..ae16b4d7c7 100644 --- a/app/models/sample_manifest/generator.rb +++ b/app/models/sample_manifest/generator.rb @@ -41,8 +41,8 @@ def print_job LabelPrinter::PrintJob.new( params[:barcode_printer], LabelPrinter::Label::SampleManifestRedirect, - only_first_label: only_first_label, - sample_manifest: sample_manifest + only_first_label:, + sample_manifest: ) end @@ -97,10 +97,10 @@ def execute_print_job def attributes params.except(:template, :barcode_printer, :only_first_label).merge( - user: user, - asset_type: asset_type, - rows_per_well: rows_per_well, - invalid_wells: invalid_wells + user:, + asset_type:, + rows_per_well:, + invalid_wells: ) end diff --git a/app/models/sequencing_pipeline.rb b/app/models/sequencing_pipeline.rb index e6410ae10e..71b25ace0e 100644 --- a/app/models/sequencing_pipeline.rb +++ b/app/models/sequencing_pipeline.rb @@ -16,7 +16,7 @@ def request_actions end def is_read_length_consistent_for_batch?(batch) # rubocop:todo Metrics/AbcSize - if (batch.requests.size == 0) || (batch.requests.first.request_metadata.nil?) + if (batch.requests.size == 0) || batch.requests.first.request_metadata.nil? # No requests selected or the pipeline doesn't contain metadata to check return true end @@ -33,7 +33,7 @@ def is_read_length_consistent_for_batch?(batch) # rubocop:todo Metrics/AbcSize end def is_flowcell_type_consistent_for_batch?(batch) # rubocop:todo Metrics/AbcSize - if (batch.requests.size == 0) || (batch.requests.first.request_metadata.nil?) + if (batch.requests.size == 0) || batch.requests.first.request_metadata.nil? # No requests selected or the pipeline doesn't contain metadata to check return true end diff --git a/app/models/state_changer/mx_tube.rb b/app/models/state_changer/mx_tube.rb index cd6371bef5..03380b8f9d 100644 --- a/app/models/state_changer/mx_tube.rb +++ b/app/models/state_changer/mx_tube.rb @@ -14,7 +14,7 @@ def associated_requests def generate_events_for(orders) orders.each do |order_id| - BroadcastEvent::PoolReleased.create!(seed: labware, user: user, properties: { order_id: order_id }) + BroadcastEvent::PoolReleased.create!(seed: labware, user: user, properties: { order_id: }) end end diff --git a/app/models/state_changer/standard_plate.rb b/app/models/state_changer/standard_plate.rb index 179933fe84..9453b1e783 100644 --- a/app/models/state_changer/standard_plate.rb +++ b/app/models/state_changer/standard_plate.rb @@ -44,7 +44,7 @@ def pending_orders def generate_events_for(orders) orders.each do |order_id| - BroadcastEvent::LibraryStart.create!(seed: labware, user: user, properties: { order_id: order_id }) + BroadcastEvent::LibraryStart.create!(seed: labware, user: user, properties: { order_id: }) end end diff --git a/app/models/strip_tube.rb b/app/models/strip_tube.rb index ebb6aa6656..014e8ca5fd 100644 --- a/app/models/strip_tube.rb +++ b/app/models/strip_tube.rb @@ -19,10 +19,10 @@ def library_source_plates end # Until we know how barcodes are going to work, we'll just override this - def self.create_with_barcode!(*args, &block) + def self.create_with_barcode!(*args, &) attributes = args.extract_options! attributes.delete(:barcode) attributes.delete(:sanger_barcode) - create!(attributes, &block) + create!(attributes, &) end end diff --git a/app/models/study.rb b/app/models/study.rb index abfb87248f..d28cd044b0 100644 --- a/app/models/study.rb +++ b/app/models/study.rb @@ -351,7 +351,7 @@ class Study < ApplicationRecord # rubocop:todo Metrics/ClassLength scope :with_remove_x_and_autosomes, -> { joins(:study_metadata).where(study_metadata: { remove_x_and_autosomes: Study::YES }) } - scope :by_state, ->(state) { where(state: state) } + scope :by_state, ->(state) { where(state:) } scope :by_user, ->(login) do @@ -517,10 +517,8 @@ def approved? end def ethical_approval_required? - ( - study_metadata.contains_human_dna == Study::YES && study_metadata.contaminated_human_dna == Study::NO && - study_metadata.commercially_available == Study::NO - ) + study_metadata.contains_human_dna == Study::YES && study_metadata.contaminated_human_dna == Study::NO && + study_metadata.commercially_available == Study::NO end def accession_service @@ -535,7 +533,7 @@ def accession_service end def send_samples_to_service? - accession_service.no_study_accession_needed || ((!study_metadata.never_release?) && accession_number?) + accession_service.no_study_accession_needed || (!study_metadata.never_release? && accession_number?) end def validate_ena_required_fields! diff --git a/app/models/study_report.rb b/app/models/study_report.rb index 8fbd163aed..d5d001404e 100644 --- a/app/models/study_report.rb +++ b/app/models/study_report.rb @@ -54,7 +54,7 @@ def perform end def schedule_report - Delayed::Job.enqueue StudyReportJob.new(id), priority: priority + Delayed::Job.enqueue StudyReportJob.new(id), priority: end def priority diff --git a/app/models/study_report/study_details.rb b/app/models/study_report/study_details.rb index 8e26348d3d..bd801f715c 100644 --- a/app/models/study_report/study_details.rb +++ b/app/models/study_report/study_details.rb @@ -4,13 +4,13 @@ module StudyReport::StudyDetails BATCH_SIZE = 1000 # This will pull out all well ids from stock plates in the study - def each_stock_well_id_in_study_in_batches(&block) # rubocop:todo Metrics/MethodLength + def each_stock_well_id_in_study_in_batches(&) # rubocop:todo Metrics/MethodLength # Stock wells are determined by the requests leading from the stock plate handle_wells( :requests, { requests: { initial_study_id: id } }, PlatePurpose.where(name: Study::STOCK_PLATE_PURPOSES).pluck(:id), - &block + & ) # Aliquot 1,2,3,4 & 5 plates are determined by the aliquots in their wells @@ -20,15 +20,15 @@ def each_stock_well_id_in_study_in_batches(&block) # rubocop:todo Metrics/Method PlatePurpose.where( name: ['Aliquot 1', 'Aliquot 2', 'Aliquot 3', 'Aliquot 4', 'Aliquot 1', 'Pre-Extracted Plate'] ).pluck(:id), - &block + & ) end # Similar to find in batches, we pluck out the relevant asset ids, then slice them into batches of the # batch size. This allows us to perform one query to grab all our ids. - def handle_wells(join, study_condition, plate_purpose_id, &block) + def handle_wells(join, study_condition, plate_purpose_id, &) asset_ids = well_report_ids(join, study_condition, plate_purpose_id) - asset_ids.each_slice(BATCH_SIZE, &block) + asset_ids.each_slice(BATCH_SIZE, &) end private :handle_wells diff --git a/app/models/submission/accession_behaviour.rb b/app/models/submission/accession_behaviour.rb index b3845f9b15..9dc0f42280 100644 --- a/app/models/submission/accession_behaviour.rb +++ b/app/models/submission/accession_behaviour.rb @@ -31,7 +31,7 @@ def check_data_release_and_accession_for_submission # rubocop:todo Metrics/AbcSi private def test_asset_group - AssetGroup.new(assets: assets) + AssetGroup.new(assets:) end def unaccessioned_samples diff --git a/app/models/submission/presenter_skeleton.rb b/app/models/submission/presenter_skeleton.rb index 2d7f176593..1931b8a3a4 100644 --- a/app/models/submission/presenter_skeleton.rb +++ b/app/models/submission/presenter_skeleton.rb @@ -25,13 +25,13 @@ def lanes_of_sequencing def cross_compatible? end - def each_submission_warning(&block) - submission.each_submission_warning(&block) + def each_submission_warning(&) + submission.each_submission_warning(&) end protected - def method_missing(name, *args, &block) + def method_missing(name, *args, &) name_without_assignment = name.to_s.sub(/=$/, '').to_sym return super unless attributes.include?(name_without_assignment) diff --git a/app/models/submission/project_validation.rb b/app/models/submission/project_validation.rb index cf45681a21..16814b94ed 100644 --- a/app/models/submission/project_validation.rb +++ b/app/models/submission/project_validation.rb @@ -45,12 +45,10 @@ def multiplier_for(request_type) private :multiplier_for def submittable? - begin - @checking_project = true - valid? - ensure - @checking_project = false - end + @checking_project = true + valid? + ensure + @checking_project = false end # Hack to be able to build order diff --git a/app/models/submission/submission_creator.rb b/app/models/submission/submission_creator.rb index d3efb68888..59d7d9ea89 100644 --- a/app/models/submission/submission_creator.rb +++ b/app/models/submission/submission_creator.rb @@ -243,7 +243,7 @@ def create_order # rubocop:todo Metrics/AbcSize # This is a legacy of the old controller... def find_samples_from_text(sample_text) names = sample_text.split(/\s+/) - samples = Sample.includes(:assets).where(['name IN (:names) OR sanger_sample_id IN (:names)', { names: names }]) + samples = Sample.includes(:assets).where(['name IN (:names) OR sanger_sample_id IN (:names)', { names: }]) name_set = Set.new(names) found_set = Set.new(samples.map { |s| [s.name, s.sanger_sample_id] }.flatten) diff --git a/app/models/submission/validations_by_template_name.rb b/app/models/submission/validations_by_template_name.rb new file mode 100644 index 0000000000..e3ed8e1517 --- /dev/null +++ b/app/models/submission/validations_by_template_name.rb @@ -0,0 +1,67 @@ +# frozen_string_literal: true +module Submission::ValidationsByTemplateName + # Template names + SCRNA_CORE_CDNA_PREP_GEM_X_5P = 'Limber-Htp - scRNA Core cDNA Prep GEM-X 5p' + + # Column headers + HEADER_TEMPLATE_NAME = 'template name' + HEADER_STUDY_NAME = 'study name' + HEADER_NUM_SAMPLES = 'scrna core number of samples per pool' + + # Applies additional validations based on the submission template type. + # + # This method determines the submission template type from the CSV data and calls the appropriate + # validation methods based on the template type. It assumes that all rows in the CSV have the same + # submission template name. + # If no match is found for the submission template name, no additional validations are performed. + # + # Uses the following instance variables: + # csv_data_rows [Array>] The CSV data rows, where each row is an array of strings. + # headers [Array] The headers of the CSV file, used to find the index of specific columns. + # errors [ActiveModel::Errors] The errors object to which validation errors are added. + # + # @return [void] + def apply_additional_validations_by_template_name + # depending on the submission template type, call additional validations + # NB. assumption that all rows in the csv have the same submission template name + index_of_template_name = headers.index(HEADER_TEMPLATE_NAME) + submission_template_name = csv_data_rows.first[index_of_template_name] + + case submission_template_name + # this validation is for the scRNA pipeline cDNA submission + when SCRNA_CORE_CDNA_PREP_GEM_X_5P + validate_scrna_core_samples_per_pool + end + end + + # Validates that the scrna core number of samples per pool is consistent for all rows with the same study name. + # + # This method groups the rows in the CSV data by the study name and checks if the scrna core number of samples + # per pool is the same for all rows within each study group. If inconsistencies are found, an error is added to + # the errors collection. + # + # @return [void] + # rubocop:disable Metrics/MethodLength + def validate_scrna_core_samples_per_pool + # Group rows by study name + index_of_study_name = headers.index(HEADER_STUDY_NAME) + grouped_rows = csv_data_rows.group_by { |row| row[index_of_study_name] } + + # Iterate through each study group + grouped_rows.each do |study_name, rows| + # Get the unique values of scrna core number of samples per pool for the group + index_of_num_samples = headers.index(HEADER_NUM_SAMPLES) + list_of_uniq_number_of_samples_per_pool = rows.pluck(index_of_num_samples).uniq + + # Check if there is more than one unique value + next unless list_of_uniq_number_of_samples_per_pool.size > 1 + errors.add( + :spreadsheet, + "Inconsistent values for column 'scRNA Core Number of Samples per Pool' for Study name '#{study_name}', " \ + 'all rows for a specific study must have the same value' + ) + end + end + + # rubocop:enable Metrics/MethodLength +end diff --git a/app/models/submission_template.rb b/app/models/submission_template.rb index f0ff0b0879..8c3aed9c80 100644 --- a/app/models/submission_template.rb +++ b/app/models/submission_template.rb @@ -49,7 +49,7 @@ def supercede name, cloned.name = cloned.name, "Superceding #{cloned.name}" cloned.save! update!(superceded_by_id: cloned.id, superceded_at: Time.zone.now) - cloned.update!(name: name) + cloned.update!(name:) end end end diff --git a/app/models/tag2_layout_template.rb b/app/models/tag2_layout_template.rb index da367e6bdb..ea3b1163a8 100644 --- a/app/models/tag2_layout_template.rb +++ b/app/models/tag2_layout_template.rb @@ -30,6 +30,6 @@ def record_template_use(plate) end def default_attributes - { tag: tag } + { tag: } end end diff --git a/app/models/tag_group.rb b/app/models/tag_group.rb index dc9aa340fb..c66bac3a49 100644 --- a/app/models/tag_group.rb +++ b/app/models/tag_group.rb @@ -30,7 +30,7 @@ def adapter_type_name end def adapter_type_name=(name) - self.adapter_type = TagGroup::AdapterType.find_by!(name: name) + self.adapter_type = TagGroup::AdapterType.find_by!(name:) end # Returns a Hash that maps from the tag index in the group to the oligo sequence for the tag diff --git a/app/models/tag_group/form_object.rb b/app/models/tag_group/form_object.rb index ced34ead0e..5a9ccbd69a 100644 --- a/app/models/tag_group/form_object.rb +++ b/app/models/tag_group/form_object.rb @@ -62,10 +62,10 @@ def check_entered_oligos # rubocop:todo Metrics/AbcSize # rubocop:enable Metrics/MethodLength - def persist! # rubocop:todo Metrics/AbcSize + def persist! # rubocop:todo Metrics/AbcSize, Metrics/MethodLength success = TagGroup.transaction do - @tag_group = TagGroup.new(name: name, adapter_type_id: adapter_type_id) + @tag_group = TagGroup.new(name:, adapter_type_id:) @tag_group.tags.build( parse_oligos_list.each_with_index.map { |oligo, i| { oligo: oligo.upcase, map_id: i + 1 } } ) diff --git a/app/models/tag_layout.rb b/app/models/tag_layout.rb index f4976bad9f..55bf3c9228 100644 --- a/app/models/tag_layout.rb +++ b/app/models/tag_layout.rb @@ -12,9 +12,6 @@ class TagLayout < ApplicationRecord attr_accessor :tags_per_well - UnknownDirection = Struct.new(:direction) - UnknownWalking = Struct.new(:walking_by) - DIRECTION_ALGORITHMS = { 'column' => 'TagLayout::InColumns', 'row' => 'TagLayout::InRows', @@ -36,6 +33,19 @@ class TagLayout < ApplicationRecord 'combinatorial sequential' => 'TagLayout::CombinatorialSequential' }.freeze + module TagLayout::DummyDirectionModule + def self.direction + end + end + + class TagLayout::DummyWalkingHelper + def initialize(*) + end + + def walking_by + end + end + self.inheritance_column = 'sti_type' serialize :substitutions, Hash @@ -50,11 +60,8 @@ class TagLayout < ApplicationRecord # The plate we'll be laying out the tags into belongs_to :plate, optional: false - validates :direction, inclusion: { in: DIRECTION_ALGORITHMS.keys } - validates :walking_by, inclusion: { in: WALKING_ALGORITHMS.keys } - - validates :direction_algorithm, presence: true - validates :walking_algorithm, presence: true + validates :direction, presence: { message: 'must define a valid algorithm' } + validates :walking_by, presence: { message: 'must define a valid algorithm' } # After creating the instance we can layout the tags into the wells. after_create :layout_tags_into_wells, if: :valid? @@ -65,11 +72,11 @@ class TagLayout < ApplicationRecord delegate :walking_by, :walk_wells, :apply_tags, to: :walking_algorithm_helper def direction=(new_direction) - self.direction_algorithm = DIRECTION_ALGORITHMS.fetch(new_direction) { UnknownDirection.new(new_direction) } + self.direction_algorithm = DIRECTION_ALGORITHMS.fetch(new_direction, TagLayout::DummyDirectionModule) end def walking_by=(walk) - self.walking_algorithm = WALKING_ALGORITHMS.fetch(walk) { UnknownWalking.new(walk) } + self.walking_algorithm = WALKING_ALGORITHMS.fetch(walk, TagLayout::DummyWalkingHelper) end def wells_in_walking_order diff --git a/app/models/tag_layout_template.rb b/app/models/tag_layout_template.rb index 274df968db..ff6f8cdd01 100644 --- a/app/models/tag_layout_template.rb +++ b/app/models/tag_layout_template.rb @@ -36,11 +36,11 @@ def create!(attributes = {}, &block) end def tag_group_name=(name) - self.tag_group = TagGroup.find_by!(name: name) + self.tag_group = TagGroup.find_by!(name:) end def tag2_group_name=(name) - self.tag2_group = TagGroup.find_by!(name: name) + self.tag2_group = TagGroup.find_by!(name:) end private @@ -54,12 +54,7 @@ def walking_algorithm_class end def tag_layout_attributes - { - tag_group: tag_group, - tag2_group: tag2_group, - direction_algorithm: direction_algorithm, - walking_algorithm: walking_algorithm - } + { tag_group:, tag2_group:, direction_algorithm:, walking_algorithm: } end def record_template_use(plate, enforce_uniqueness) diff --git a/app/models/tag_set.rb b/app/models/tag_set.rb index 2650596d03..1b4eaf63cd 100644 --- a/app/models/tag_set.rb +++ b/app/models/tag_set.rb @@ -39,10 +39,10 @@ def tag_group_adapter_types_must_match end def tag_group_name=(name) - self.tag_group = TagGroup.find_by!(name: name) + self.tag_group = TagGroup.find_by!(name:) end def tag2_group_name=(name) - self.tag2_group = TagGroup.find_by!(name: name) + self.tag2_group = TagGroup.find_by!(name:) end end diff --git a/app/models/tag_substitution.rb b/app/models/tag_substitution.rb index 19ecfef63a..a7932b473f 100644 --- a/app/models/tag_substitution.rb +++ b/app/models/tag_substitution.rb @@ -119,7 +119,7 @@ def save # rubocop:todo Metrics/MethodLength # # @return [void] def template_asset=(asset) - @substitutions = asset.aliquots.includes(:sample).map { |aliquot| Substitution.new(aliquot: aliquot) } + @substitutions = asset.aliquots.includes(:sample).map { |aliquot| Substitution.new(aliquot:) } @name = asset.display_name end diff --git a/app/models/tag_substitution/substitution.rb b/app/models/tag_substitution/substitution.rb index 5fd6498292..108b13bb72 100644 --- a/app/models/tag_substitution/substitution.rb +++ b/app/models/tag_substitution/substitution.rb @@ -124,10 +124,10 @@ def substitute_tags # @param oligo_index [Hash] A hash of oligo sequences indexed by oligo id. # # @return [String] A description of the substitution - def comment(oligo_index) # rubocop:todo Metrics/AbcSize + def comment(oligo_index) return '' unless updated? - comment = +"Sample #{sample_id}:" + comment = "Sample #{sample_id}:" if substitute_tag? comment << " Tag changed from #{oligo_index[original_tag_id]} to #{oligo_index[substitute_tag_id]};" end @@ -173,7 +173,7 @@ def substitute_tag2? end def find_matching_aliquots - attributes = { sample_id: sample_id, library_id: library_id } + attributes = { sample_id:, library_id: } attributes[:tag_id] = original_tag_id if original_tag_id attributes[:tag2_id] = original_tag2_id if original_tag2_id Aliquot.where(attributes).ids diff --git a/app/models/transfer/between_plate_and_tubes.rb b/app/models/transfer/between_plate_and_tubes.rb index 683649687e..3945c1641b 100644 --- a/app/models/transfer/between_plate_and_tubes.rb +++ b/app/models/transfer/between_plate_and_tubes.rb @@ -92,7 +92,7 @@ def build_well_to_tube_transfers # rubocop:todo Metrics/MethodLength well_to_tubes.build( @transfers.map do |source, (destination, stock_wells)| tube_to_stock_wells[destination].concat(stock_wells) - { source: source, destination: destination } + { source:, destination: } end ).map(&:save!) diff --git a/app/models/tube.rb b/app/models/tube.rb index 56df111310..9a10a6d7d4 100644 --- a/app/models/tube.rb +++ b/app/models/tube.rb @@ -83,7 +83,7 @@ def after_comment_addition(comment) comments.add_comment_to_submissions(comment) end - def self.create_with_barcode!(*args, &block) + def self.create_with_barcode!(*args, &) attributes = args.extract_options!.symbolize_keys barcode, prefix = extract_barcode(args, attributes) @@ -94,7 +94,7 @@ def self.create_with_barcode!(*args, &block) # this is to control the order of barcode addition so that it gets set as the 'primary' barcode foreign_barcode = attributes.delete(:foreign_barcode) - tube = create!(attributes.merge(sanger_barcode: { prefix: prefix, number: barcode }), &block) + tube = create!(attributes.merge(sanger_barcode: { prefix: prefix, number: barcode }), &) tube.foreign_barcode = foreign_barcode if foreign_barcode tube.reload diff --git a/app/models/user.rb b/app/models/user.rb index 4663d0e643..d6a19f5c17 100644 --- a/app/models/user.rb +++ b/app/models/user.rb @@ -93,7 +93,7 @@ def study_and_project_roles end def logout_path - configatron.authentication == 'sanger-sso' ? (configatron.sso_logout_url).to_s : '/logout' + configatron.authentication == 'sanger-sso' ? configatron.sso_logout_url.to_s : '/logout' end def profile_incomplete? diff --git a/app/models/user/authentication.rb b/app/models/user/authentication.rb index 2c156b1363..fb54b2be2d 100644 --- a/app/models/user/authentication.rb +++ b/app/models/user/authentication.rb @@ -43,7 +43,7 @@ def authenticate(login, password) when 'none' raise StandardError, 'Can only disable authentication in development' unless Rails.env.development? - User.find_by(login: login) + User.find_by(login:) else authenticated = authenticate_by_local(login, password) end @@ -83,7 +83,7 @@ def authenticate_with_ldap(login, password) # rubocop:todo Metrics/AbcSize, Metr end def register_or_update_via_ldap(login) - u = find_or_create_by(login: login) + u = find_or_create_by(login:) if u.nil? logger.error "Failed to find or create user #{login}" else @@ -95,7 +95,7 @@ def register_or_update_via_ldap(login) module Local def authenticate_by_local(login, password) - u = find_by(login: login) # need to get the salt + u = find_by(login:) # need to get the salt u && u.authenticated?(password) ? u : nil end end diff --git a/app/models/uuid.rb b/app/models/uuid.rb index 9289e1223e..ff2223d269 100644 --- a/app/models/uuid.rb +++ b/app/models/uuid.rb @@ -75,11 +75,11 @@ def object scope :with_resource_type, ->(type) { where(resource_type: type.to_s) } scope :include_resource, -> { includes(:resource) } - scope :with_external_id, ->(external_id) { where(external_id: external_id) } + scope :with_external_id, ->(external_id) { where(external_id:) } scope :with_resource_by_type_and_id, ->(t, id) { where(resource_type: t, resource_id: id) } # Limits the query to resources of the given type if provided. Otherwise returns all - scope :limited_to_resource, ->(resource_type) { resource_type.nil? ? all : where(resource_type: resource_type) } + scope :limited_to_resource, ->(resource_type) { resource_type.nil? ? all : where(resource_type:) } before_validation do |record| record.external_id = Uuid.generate_uuid if record.new_record? && record.external_id.blank? @@ -102,7 +102,7 @@ def self.uuid?(value) end def self.find_uuid_instance!(resource_type, resource_id) - find_by!(resource_type: resource_type, resource_id: resource_id) + find_by!(resource_type:, resource_id:) end # Find the uuid corresponding id and system. @@ -111,7 +111,7 @@ def self.find_uuid_instance!(resource_type, resource_id) # @return [String, nil] the uuid if found. def self.find_uuid(resource_type, resource_id) - find_by(resource_type: resource_type, resource_id: resource_id).try(:external_id) + find_by(resource_type:, resource_id:).try(:external_id) end # Find an Uuid or create it if needed. @@ -121,7 +121,7 @@ def self.find_uuid(resource_type, resource_id) def self.find_uuid!(resource_type, resource_id) return unless resource_id # return nil for nil - find_uuid(resource_type, resource_id) || create!(resource_type: resource_type, resource_id: resource_id).external_id + find_uuid(resource_type, resource_id) || create!(resource_type:, resource_id:).external_id end # Given a list of internal ids, create uuids in bulk diff --git a/app/models/well.rb b/app/models/well.rb index 06d5b158cb..f8106b4ad5 100644 --- a/app/models/well.rb +++ b/app/models/well.rb @@ -199,7 +199,7 @@ def subject_type end def outer_request(submission_id) - outer_requests.order(id: :desc).find_by(submission_id: submission_id) + outer_requests.order(id: :desc).find_by(submission_id:) end def qc_results_by_key @@ -287,14 +287,14 @@ def update_gender_markers!(gender_markers, resource) # rubocop:todo Metrics/AbcS events.update_gender_markers!(resource) end - well_attribute.update!(gender_markers: gender_markers) + well_attribute.update!(gender_markers:) end # rubocop:enable Metrics/MethodLength def update_sequenom_count!(sequenom_count, resource) events.update_sequenom_count!(resource) unless well_attribute.sequenom_count == sequenom_count - well_attribute.update!(sequenom_count: sequenom_count) + well_attribute.update!(sequenom_count:) end # The sequenom pass value is either the string 'Unknown' or it is the combination of gender marker values. diff --git a/app/models/work_completion/labware_completion.rb b/app/models/work_completion/labware_completion.rb index afcd491f68..7b60a8ecb7 100644 --- a/app/models/work_completion/labware_completion.rb +++ b/app/models/work_completion/labware_completion.rb @@ -59,7 +59,7 @@ def fire_events seed: work_completion, user: work_completion.user, properties: { - order_id: order_id + order_id: } ) end diff --git a/app/models/work_order/factory.rb b/app/models/work_order/factory.rb index 713d5e1051..adb74da928 100644 --- a/app/models/work_order/factory.rb +++ b/app/models/work_order/factory.rb @@ -22,7 +22,7 @@ def create_work_orders! .group_by(&:asset_id) .map do |_asset_id, requests| state = requests.first.state - WorkOrder.create!(work_order_type: work_order_type, requests: requests, state: state) + WorkOrder.create!(work_order_type:, requests:, state:) end end diff --git a/app/resources/api/v2/bait_library_layout_resource.rb b/app/resources/api/v2/bait_library_layout_resource.rb new file mode 100644 index 0000000000..6b99434dfd --- /dev/null +++ b/app/resources/api/v2/bait_library_layout_resource.rb @@ -0,0 +1,80 @@ +# frozen_string_literal: true + +module Api + module V2 + # @todo This documentation does not yet include a detailed description of what this resource represents. + # @todo This documentation does not yet include detailed descriptions for relationships, attributes and filters. + # @todo This documentation does not yet include any example usage of the API via cURL or similar. + # + # @note This resource cannot be modified after creation: its endpoint will not accept `PATCH` requests. + # @note Access this resource via the `/api/v2/bait_library_layouts/` endpoint. + # + # Provides a JSON:API representation of {BaitLibraryLayout}. + # + # For more information about JSON:API see the [JSON:API Specifications](https://jsonapi.org/format/) + # or look at the [JSONAPI::Resources](http://jsonapi-resources.com/) package for Sequencescape's implementation + # of the JSON:API standard. + class BaitLibraryLayoutResource < BaseResource + # @!attribute [w] plate_uuid + # This is declared for convenience where the plate is not available to set as a relationship. + # Setting this attribute alongside the `plate` relationship will prefer the relationship value. + # @deprecated Use the `plate` relationship instead. + # @param value [String] The UUID of the plate for this bait library layout. + # @return [Void] + # @see #plate + attribute :plate_uuid + + def plate_uuid=(value) + @model.plate = Plate.with_uuid(value).first + end + + # @!attribute [w] user_uuid + # This is declared for convenience where the user is not available to set as a relationship. + # Setting this attribute alongside the `user` relationship will prefer the relationship value. + # @deprecated Use the `user` relationship instead. + # @param value [String] The UUID of the user who created this bait library layout. + # @return [Void] + # @see #user + attribute :user_uuid + + def user_uuid=(value) + @model.user = User.with_uuid(value).first + end + + # @!attribute [r] layout + # @return [Hash] The layout of the bait libraries on the plate. + attribute :layout, readonly: true + + # # @!attribute [r] uuid + # # @return [String] The UUID of the state change. + attribute :uuid, readonly: true + + ### + # Relationships + ### + + # @!attribute [rw] user + # Setting this relationship alongside the `user_uuid` attribute will override the attribute value. + # @return [UserResource] The user who created this bait library layout. + # @note This relationship is required. + has_one :user + + # @!attribute [rw] plate + # Setting this relationship alongside the `plate_uuid` attribute will override the attribute value. + # @return [PlateResource] The plate for this bait library layout. + # @note This relationship is required. + has_one :plate + + def self.creatable_fields(context) + # The layout is generated by the system. + # The UUID is set by the system. + super - %i[layout uuid] + end + + def fetchable_fields + # UUIDs for relationships are not fetchable. They should be accessed via the relationship itself. + super - %i[plate_uuid user_uuid] + end + end + end +end diff --git a/app/resources/api/v2/plate_purpose_resource.rb b/app/resources/api/v2/plate_purpose_resource.rb index 138e929181..58edb41b51 100644 --- a/app/resources/api/v2/plate_purpose_resource.rb +++ b/app/resources/api/v2/plate_purpose_resource.rb @@ -60,7 +60,7 @@ class PlatePurposeResource < BaseResource # @param name [String] the name of the asset shape # @return [void] def asset_shape=(name) - @model.asset_shape = (AssetShape.find_by!(name: name) if name.present?) || AssetShape.default + @model.asset_shape = (AssetShape.find_by!(name:) if name.present?) || AssetShape.default end # Returns the name of the asset shape of the plate purpose. diff --git a/app/resources/api/v2/pooled_plate_creation_resource.rb b/app/resources/api/v2/pooled_plate_creation_resource.rb new file mode 100644 index 0000000000..3db50371c7 --- /dev/null +++ b/app/resources/api/v2/pooled_plate_creation_resource.rb @@ -0,0 +1,93 @@ +# frozen_string_literal: true + +module Api + module V2 + # @todo This documentation does not yet include a detailed description of what this resource represents. + # @todo This documentation does not yet include detailed descriptions for relationships, attributes and filters. + # @todo This documentation does not yet include any example usage of the API via cURL or similar. + # + # @note This resource cannot be modified after creation: its endpoint will not accept `PATCH` requests. + # @note Access this resource via the `/api/v2/pooled_plate_creation/` endpoint. + # + # Provides a JSON:API representation of {PooledPlateCreation}. + # + # For more information about JSON:API see the [JSON:API Specifications](https://jsonapi.org/format/) + # or look at the [JSONAPI::Resources](http://jsonapi-resources.com/) package for Sequencescape's implementation + # of the JSON:API standard. + class PooledPlateCreationResource < BaseResource + ### + # Attributes + ### + + # @!attribute [w] child_purpose_uuid + # @param value [String] The UUID of a child purpose to use in the creation of the child plate. + # @return [Void] + attribute :child_purpose_uuid + + def child_purpose_uuid=(value) + @model.child_purpose = Purpose.with_uuid(value).first + end + + # @!attribute [w] parent_uuids + # This is declared for convenience where parents are not available to set as a relationship. + # Setting this attribute alongside the `parents` relationship will prefer the relationship value. + # @deprecated Use the `parents` relationship instead. + # @param value [Array] The UUIDs of labware that will be the parents for the created plate. + # @return [Void] + # @see #parents + attribute :parent_uuids + + def parent_uuids=(value) + @model.parents = value.map { |uuid| Labware.with_uuid(uuid).first } + end + + # @!attribute [w] user_uuid + # This is declared for convenience where the user is not available to set as a relationship. + # Setting this attribute alongside the `user` relationship will prefer the relationship value. + # @deprecated Use the `user` relationship instead. + # @param value [String] The UUID of the user who initiated the creation of this pooled plate. + # @return [Void] + # @see #user + attribute :user_uuid + + def user_uuid=(value) + @model.user = User.with_uuid(value).first + end + + # @!attribute [r] uuid + # @return [String] The UUID of the state change. + attribute :uuid, readonly: true + + ### + # Relationships + ### + + # @!attribute [r] child + # @return [PlateResource] The child plate which was created. + has_one :child, class_name: 'Plate' + + # @!attribute [rw] parents + # Setting this relationship alongside the `parent_uuids` attribute will override the attribute value. + # @return [Array] An array of the parents of the plate being created. + # @note This relationship is required. + has_many :parents, class_name: 'Labware' + + # @!attribute [rw] user + # Setting this relationship alongside the `user_uuid` attribute will override the attribute value. + # @return [UserResource] The user who initiated the creation of the pooled plate. + # @note This relationship is required. + has_one :user + + def self.creatable_fields(context) + # UUID is set by the system. + super - %i[uuid] + end + + def fetchable_fields + # The tube_attributes attribute is only available during resource creation. + # UUIDs for relationships are not fetchable. They should be accessed via the relationship itself. + super - %i[child_purpose_uuid parent_uuids user_uuid] + end + end + end +end diff --git a/app/resources/api/v2/request_metadata_resource.rb b/app/resources/api/v2/request_metadata_resource.rb new file mode 100644 index 0000000000..ba29d757bc --- /dev/null +++ b/app/resources/api/v2/request_metadata_resource.rb @@ -0,0 +1,48 @@ +# frozen_string_literal: true + +module Api + module V2 + # @todo This documentation does not yet include a detailed description of what this resource represents. + # @todo This documentation does not yet include detailed descriptions for relationships, attributes and filters. + # @todo This documentation does not yet include any example usage of the API via cURL or similar. + # + # @note Access this resource via the `/api/v2/requests_metadata/` endpoint. + # + # Provides a JSON:API representation of {Request::Metadata}. + # + # For more information about JSON:API see the [JSON:API Specifications](https://jsonapi.org/format/) + # or look at the [JSONAPI::Resources](http://jsonapi-resources.com/) package for Sequencescape's implementation + # of the JSON:API standard. + class RequestMetadataResource < BaseResource + # NB. request_metadata has been added to config/initializers/inflections.rb to make this class name + # work otherwise it expects RequestMetadatumResource + + # Sets add_model_hint true by default, this allows updates from Limber, otherwise get a + # 500 error as it looks for resource Api::V2::MetadatumResource + model_name 'Request::Metadata' + + # Associations: + has_one :request + + ### + # Attributes + ### + + # @!attribute [r] number_of_samples_per_pool + # @return [Int] the number_of_samples_per_pool. + attribute :number_of_samples_per_pool, readonly: true + + # @!attribute [r] cells_per_chip_well + # @return [Int] the cells_per_chip_well. + attribute :cells_per_chip_well, readonly: true + + # Filters + + # Custom methods + # These shouldn't be used for business logic, and a more about + # I/O and isolating implementation details. + + # Class method overrides + end + end +end diff --git a/app/resources/api/v2/request_resource.rb b/app/resources/api/v2/request_resource.rb index 1c5788ed2f..bf12598965 100644 --- a/app/resources/api/v2/request_resource.rb +++ b/app/resources/api/v2/request_resource.rb @@ -31,6 +31,7 @@ class RequestResource < BaseResource has_one :primer_panel has_one :pre_capture_pool has_many :poly_metadata, as: :metadatable, class_name: 'PolyMetadatum' + has_one :request_metadata, class_name: 'RequestMetadata', foreign_key_on: :related # Attributes attribute :uuid, readonly: true diff --git a/app/resources/api/v2/sample_metadata_resource.rb b/app/resources/api/v2/sample_metadata_resource.rb index 200bf8c489..23dc18d269 100644 --- a/app/resources/api/v2/sample_metadata_resource.rb +++ b/app/resources/api/v2/sample_metadata_resource.rb @@ -15,6 +15,9 @@ module V2 # or look at the [JSONAPI::Resources](http://jsonapi-resources.com/) package for Sequencescape's implementation # of the JSON:API standard. class SampleMetadataResource < BaseResource + # NB. sample_metadata has been added to config/initializers/inflections.rb to make this class name + # work otherwise it expects SampleMetadatumResource + # Set add_model_hint true to allow updates from Limber, otherwise get a # 500 error as it looks for resource Api::V2::MetadatumResource model_name 'Sample::Metadata', add_model_hint: true diff --git a/app/resources/api/v2/shared_behaviour/labware.rb b/app/resources/api/v2/shared_behaviour/labware.rb index 6f0858fa1d..5ad2156de4 100644 --- a/app/resources/api/v2/shared_behaviour/labware.rb +++ b/app/resources/api/v2/shared_behaviour/labware.rb @@ -57,11 +57,9 @@ module Labware filter :purpose_id, apply: ->(records, value, _options) { records.where(plate_purpose_id: value) } filter :without_children, apply: ->(records, _value, _options) { records.without_children } filter :created_at_gt, - apply: - (lambda { |records, value, _options| records.where('labware.created_at > ?', value[0].to_date) }) + apply: lambda { |records, value, _options| records.where('labware.created_at > ?', value[0].to_date) } filter :updated_at_gt, - apply: - (lambda { |records, value, _options| records.where('labware.updated_at > ?', value[0].to_date) }) + apply: lambda { |records, value, _options| records.where('labware.updated_at > ?', value[0].to_date) } filter :include_used, apply: ->(records, value, _options) { records.include_labware_with_children(value) } end diff --git a/app/resources/api/v2/specific_tube_creation_resource.rb b/app/resources/api/v2/specific_tube_creation_resource.rb new file mode 100644 index 0000000000..d3cfae2529 --- /dev/null +++ b/app/resources/api/v2/specific_tube_creation_resource.rb @@ -0,0 +1,108 @@ +# frozen_string_literal: true + +module Api + module V2 + # @todo This documentation does not yet include a detailed description of what this resource represents. + # @todo This documentation does not yet include detailed descriptions for relationships, attributes and filters. + # @todo This documentation does not yet include any example usage of the API via cURL or similar. + # + # @note This resource cannot be modified after creation: its endpoint will not accept `PATCH` requests. + # @note Access this resource via the `/api/v2/specific_tube_creations/` endpoint. + # + # Provides a JSON:API representation of {SpecificTubeCreation}. + # + # For more information about JSON:API see the [JSON:API Specifications](https://jsonapi.org/format/) + # or look at the [JSONAPI::Resources](http://jsonapi-resources.com/) package for Sequencescape's implementation + # of the JSON:API standard. + class SpecificTubeCreationResource < BaseResource + ### + # Attributes + ### + + # @!attribute [w] child_purpose_uuids + # @param value [Array] Array of UUIDs for child purposes to use in the creation of tubes. + # @return [Void] + attribute :child_purpose_uuids + + def child_purpose_uuids=(value) + @model.child_purposes = value.map { |uuid| Purpose.with_uuid(uuid).first } + end + + # @!attribute [w] parent_uuids + # This is declared for convenience where the parent is not available to set as a relationship. + # Setting this attribute alongside the `parents` relationship will prefer the relationship value. + # @deprecated Use the `parents` relationship instead. + # @param value [Array] The UUIDs of labware that will be the parents for all tubes created. + # @return [Void] + # @see #parents + attribute :parent_uuids + + def parent_uuids=(value) + @model.parents = value.map { |uuid| Labware.with_uuid(uuid).first } + end + + # @!attribute [w] tube_attributes + # @param value [Array] Hashes defining the attributes to apply to each tube being created. + # This might be used to set custom attributes on the tubes, such as name. + # @example Setting the name of the tubes being created. + # [{ name: 'Tube one' }, { name: 'Tube two' }] + # @return [Void] + attribute :tube_attributes + + def tube_attributes=(value) + return if value.nil? + + # Convert ActionController::Parameters into hashes. + @model.tube_attributes = value.map(&:to_unsafe_h) + end + + # @!attribute [w] user_uuid + # This is declared for convenience where the user is not available to set as a relationship. + # Setting this attribute alongside the `user` relationship will prefer the relationship value. + # @deprecated Use the `user` relationship instead. + # @param value [String] The UUID of the user who initiated the creation of tubes. + # @return [Void] + # @see #user + attribute :user_uuid + + def user_uuid=(value) + @model.user = User.with_uuid(value).first + end + + # @!attribute [r] uuid + # @return [String] The UUID of the state change. + attribute :uuid, readonly: true + + ### + # Relationships + ### + + # @!attribute [r] children + # @return [Array] An array of tubes that were created. + has_many :children, class_name: 'Tube' + + # @!attribute [rw] parents + # Setting this relationship alongside the `parent_uuids` attribute will override the attribute value. + # @return [Array] An array of the parents of the tubes being created. + # @note This relationship is required. + has_many :parents, class_name: 'Labware' + + # @!attribute [rw] user + # Setting this relationship alongside the `user_uuid` attribute will override the attribute value. + # @return [UserResource] The user who initiated the creation of tubes. + # @note This relationship is required. + has_one :user + + def self.creatable_fields(context) + # UUID is set by the system. + super - %i[uuid] + end + + def fetchable_fields + # The tube_attributes attribute is only available during resource creation. + # UUIDs for relationships are not fetchable. They should be accessed via the relationship itself. + super - %i[child_purpose_uuids parent_uuids tube_attributes user_uuid] + end + end + end +end diff --git a/app/resources/api/v2/state_change_resource.rb b/app/resources/api/v2/state_change_resource.rb index 16810e08db..53f8388aad 100644 --- a/app/resources/api/v2/state_change_resource.rb +++ b/app/resources/api/v2/state_change_resource.rb @@ -45,6 +45,7 @@ class StateChangeResource < BaseResource # @!attribute [w] target_uuid # This is declared for convenience where the target is not available to set as a relationship. # Setting this attribute alongside the `target` relationship will prefer the relationship value. + # @deprecated Use the `target` relationship instead. # @param value [String] The UUID of the target labware this state change applies to. # @return [Void] # @see #target @@ -57,6 +58,7 @@ def target_uuid=(value) # @!attribute [w] user_uuid # This is declared for convenience where the user is not available to set as a relationship. # Setting this attribute alongside the `user` relationship will prefer the relationship value. + # @deprecated Use the `user` relationship instead. # @param value [String] The UUID of the user who initiated this state change. # @return [Void] # @see #user diff --git a/app/resources/api/v2/tag_layout_resource.rb b/app/resources/api/v2/tag_layout_resource.rb new file mode 100644 index 0000000000..edbf0661a8 --- /dev/null +++ b/app/resources/api/v2/tag_layout_resource.rb @@ -0,0 +1,157 @@ +# frozen_string_literal: true + +module Api + module V2 + # @todo This documentation does not yet include a detailed description of what this resource represents. + # @todo This documentation does not yet include detailed descriptions for relationships, attributes and filters. + # @todo This documentation does not yet include any example usage of the API via cURL or similar. + # + # @note This resource cannot be modified after creation: its endpoint will not accept `PATCH` requests. + # @note Access this resource via the `/api/v2/tag_layouts/` endpoint. + # + # Provides a JSON:API representation of {TagLayout}. + # + # For more information about JSON:API see the [JSON:API Specifications](https://jsonapi.org/format/) + # or look at the [JSONAPI::Resources](http://jsonapi-resources.com/) package for Sequencescape's implementation + # of the JSON:API standard. + class TagLayoutResource < BaseResource + ### + # Attributes + ### + + # @!attribute [rw] direction + # The name of the algorithm defining the direction of the tag layout. + # @return [String] + # @note This attribute is required. + attribute :direction + + # @!attribute [rw] initial_tag + # An offset for the tag set indicating which tag to start with in the layout. + # @return [Integer] + attribute :initial_tag + + # @!attribute [w] plate_uuid + # This is declared for convenience where the {Plate} is not available to set as a relationship. + # Setting this attribute alongside the `plate` relationship will prefer the relationship value. + # @deprecated Use the `plate` relationship instead. + # @param value [String] The UUID of the {Plate} this tag layout applies to. + # @return [Void] + # @see #plate + attribute :plate_uuid + + def plate_uuid=(value) + @model.plate = Plate.with_uuid(value).first + end + + # @!attribute [rw] substitutions + # A hash of substitutions to be applied to the tag layout. + # @return [Hash] + attribute :substitutions + + def substitutions=(value) + @model.substitutions = + if value.is_a?(ActionController::Parameters) + value.to_unsafe_h # We must unwrap the parameters to a real Hash. + else + value + end + end + + # @!attribute [w] tag_group_uuid + # This is declared for convenience where the {TagGroup} is not available to set as a relationship. + # Setting this attribute alongside the `tag_group` relationship will prefer the relationship value. + # @deprecated Use the `tag_group` relationship instead. + # @param value [String] The UUID of the {TagGroup} used in this tag layout. + # @return [Void] + # @see #tag_group + attribute :tag_group_uuid + + def tag_group_uuid=(value) + @model.tag_group = TagGroup.with_uuid(value).first + end + + # @!attribute [w] tag2_group_uuid + # This is declared for convenience where the second {TagGroup} is not available to set as a relationship. + # Setting this attribute alongside the `tag2_group` relationship will prefer the relationship value. + # @deprecated Use the `tag2_group` relationship instead. + # @param value [String] The UUID of the second {TagGroup} used in this tag layout. + # @return [Void] + # @see #tag2_group + attribute :tag2_group_uuid + + def tag2_group_uuid=(value) + @model.tag2_group = TagGroup.with_uuid(value).first + end + + # @!attribute [rw] tags_per_well + # The number of tags in each well. + # This is only used and/or returned by specific tag layout {walking_by} algorithms. + # At other times, this value will be `nil`. + # @return [Integer] + attribute :tags_per_well + + # @!attribute [w] user_uuid + # This is declared for convenience where the {User} is not available to set as a relationship. + # Setting this attribute alongside the `user` relationship will prefer the relationship value. + # @deprecated Use the `user` relationship instead. + # @param value [String] The UUID of the {User} who initiated this state change. + # @return [Void] + # @see #user + attribute :user_uuid + + def user_uuid=(value) + @model.user = User.with_uuid(value).first + end + + # @!attribute [r] uuid + # @return [String] The UUID of the state change. + attribute :uuid, readonly: true + + # @!attribute [rw] walking_by + # The name of the algorithm defining the way of walking through the tag layout. + # @return [String] + # @note This attribute is required. + attribute :walking_by + + ### + # Relationships + ### + + # @!attribute [rw] plate + # Setting this relationship alongside the `plate_uuid` attribute will override the attribute value. + # @return [Api::V2::PlateResource] The plate this tag layout applies to. + # @note This relationship is required. + has_one :plate + + # @!attribute [rw] tag_group + # Setting this relationship alongside the `tag_group_uuid` attribute will override the attribute value. + # A relationship for the primary tag group associated with the tag layout template. + # @return [Api::V2::TagGroupResource] + # @note This relationship is required. + has_one :tag_group + + # @!attribute [rw] tag2_group + # Setting this relationship alongside the `tag2_group_uuid` attribute will override the attribute value. + # A relationship for the secondary tag group associated with the tag layout template. + # This is used during dual indexing, but will not be found during single indexing. + # @return [Api::V2::TagGroupResource] + has_one :tag2_group, class_name: 'TagGroup' + + # @!attribute [rw] user + # Setting this relationship alongside the `user_uuid` attribute will override the attribute value. + # @return [Api::V2::UserResource] The user who initiated this state change. + # @note This relationship is required. + has_one :user + + def self.creatable_fields(context) + # UUID is set by the system. + super - %i[uuid] + end + + def fetchable_fields + # UUIDs for relationships are not fetchable. They should be accessed via the relationship itself. + super - %i[plate_uuid tag_group_uuid tag2_group_uuid user_uuid] + end + end + end +end diff --git a/app/sample_manifest_excel/sample_manifest_excel/manifest_type_list.rb b/app/sample_manifest_excel/sample_manifest_excel/manifest_type_list.rb index 52a6242dbc..e4dc731db5 100644 --- a/app/sample_manifest_excel/sample_manifest_excel/manifest_type_list.rb +++ b/app/sample_manifest_excel/sample_manifest_excel/manifest_type_list.rb @@ -12,8 +12,8 @@ def initialize(manifest_types = {}) yield self if block_given? end - def each(&block) - manifest_types.each(&block) + def each(&) + manifest_types.each(&) end # Hash version of the manifest_types.yml config file diff --git a/app/sample_manifest_excel/sample_manifest_excel/test_download.rb b/app/sample_manifest_excel/sample_manifest_excel/test_download.rb index 5fa47cf8c2..b2be15ba03 100644 --- a/app/sample_manifest_excel/sample_manifest_excel/test_download.rb +++ b/app/sample_manifest_excel/sample_manifest_excel/test_download.rb @@ -10,7 +10,7 @@ class TestDownload attr_reader :worksheet def initialize(attributes = {}) - @worksheet = SampleManifestExcel::Worksheet::TestWorksheet.new(attributes.merge(workbook: workbook)) + @worksheet = SampleManifestExcel::Worksheet::TestWorksheet.new(attributes.merge(workbook:)) end end end diff --git a/app/sample_manifest_excel/sample_manifest_excel/upload/base.rb b/app/sample_manifest_excel/sample_manifest_excel/upload/base.rb index f9618fc11f..e4c01c8380 100644 --- a/app/sample_manifest_excel/sample_manifest_excel/upload/base.rb +++ b/app/sample_manifest_excel/sample_manifest_excel/upload/base.rb @@ -64,8 +64,8 @@ def derive_sample_manifest return unless start_row.present? && sanger_sample_id_column.present? sanger_sample_id = data.cell(1, sanger_sample_id_column.number) - SampleManifestAsset.find_by(sanger_sample_id: sanger_sample_id)&.sample_manifest || - Sample.find_by(sanger_sample_id: sanger_sample_id)&.sample_manifest + SampleManifestAsset.find_by(sanger_sample_id:)&.sample_manifest || + Sample.find_by(sanger_sample_id:)&.sample_manifest end ## diff --git a/app/sample_manifest_excel/sample_manifest_excel/upload/data.rb b/app/sample_manifest_excel/sample_manifest_excel/upload/data.rb index 23d32450c8..b9679f9487 100644 --- a/app/sample_manifest_excel/sample_manifest_excel/upload/data.rb +++ b/app/sample_manifest_excel/sample_manifest_excel/upload/data.rb @@ -41,8 +41,8 @@ def initialize(file) # rubocop:todo Metrics/MethodLength @data ||= [] end - def each(&block) - data.each(&block) + def each(&) + data.each(&) end def file_extension diff --git a/app/sample_manifest_excel/sample_manifest_excel/upload/processor/plate.rb b/app/sample_manifest_excel/sample_manifest_excel/upload/processor/plate.rb index fd4df3a5fd..ceb3432c99 100644 --- a/app/sample_manifest_excel/sample_manifest_excel/upload/processor/plate.rb +++ b/app/sample_manifest_excel/sample_manifest_excel/upload/processor/plate.rb @@ -100,9 +100,9 @@ def non_matching_retention_instructions_for_plates end [nil, nil] end - # rubocop:enable Metrics/PerceivedComplexity, Metrics/CyclomaticComplexity, Metrics/AbcSize, Metrics/MethodLength - def check_row_retention_value(row, plate_barcode, retention_instructions) + + def check_row_retention_value(row, plate_barcode, retention_instructions) # rubocop:todo Metrics/MethodLength # if present the column is mandatory row_retention_value = row.value('retention_instruction') return 'Value cannot be blank.' if row_retention_value.nil? diff --git a/app/sample_manifest_excel/sample_manifest_excel/upload/processor/tube_rack.rb b/app/sample_manifest_excel/sample_manifest_excel/upload/processor/tube_rack.rb index 88b46feebd..9b8f27ec02 100644 --- a/app/sample_manifest_excel/sample_manifest_excel/upload/processor/tube_rack.rb +++ b/app/sample_manifest_excel/sample_manifest_excel/upload/processor/tube_rack.rb @@ -58,7 +58,7 @@ def retrieve_tube_rack_barcodes_from_manifest # it has been processed before and should not be re-processed def check_if_tube_racks_present @tube_rack_barcodes_from_manifest.each do |barcode| - existing_barcode_record = Barcode.includes(:asset).find_by(barcode: barcode) + existing_barcode_record = Barcode.includes(:asset).find_by(barcode:) return true if !existing_barcode_record.nil? && !existing_barcode_record.asset.nil? end false diff --git a/app/sample_manifest_excel/sample_manifest_excel/upload/row.rb b/app/sample_manifest_excel/sample_manifest_excel/upload/row.rb index 75e61c0f3f..2590f44b58 100644 --- a/app/sample_manifest_excel/sample_manifest_excel/upload/row.rb +++ b/app/sample_manifest_excel/sample_manifest_excel/upload/row.rb @@ -106,7 +106,7 @@ def changed? end def update_specialised_fields(tag_group) - specialised_fields.each { |specialised_field| specialised_field.update(tag_group: tag_group) } + specialised_fields.each { |specialised_field| specialised_field.update(tag_group:) } end def update_metadata_fields @@ -179,7 +179,7 @@ def validate_sample private def manifest_asset - @manifest_asset ||= cache.find_by(sanger_sample_id: sanger_sample_id) + @manifest_asset ||= cache.find_by(sanger_sample_id:) end def sanger_sample_id_exists? diff --git a/app/sample_manifest_excel/sample_manifest_excel/upload/rows.rb b/app/sample_manifest_excel/sample_manifest_excel/upload/rows.rb index 1772a79cb7..ceacc049f2 100644 --- a/app/sample_manifest_excel/sample_manifest_excel/upload/rows.rb +++ b/app/sample_manifest_excel/sample_manifest_excel/upload/rows.rb @@ -23,8 +23,8 @@ def initialize(data, columns, cache = SampleManifestAsset) @items = create_rows(cache) end - def each(&block) - items.each(&block) + def each(&) + items.each(&) end # Return values for rows for a particular column number diff --git a/app/sample_manifest_excel/sample_manifest_excel/worksheet/test_worksheet.rb b/app/sample_manifest_excel/sample_manifest_excel/worksheet/test_worksheet.rb index 42ae1cfbe6..12a59a7463 100644 --- a/app/sample_manifest_excel/sample_manifest_excel/worksheet/test_worksheet.rb +++ b/app/sample_manifest_excel/sample_manifest_excel/worksheet/test_worksheet.rb @@ -87,10 +87,10 @@ def create_sample_manifest # rubocop:todo Metrics/MethodLength when /plate/ FactoryBot.create( :pending_plate_sample_manifest, - num_plates: num_plates, - num_filled_wells_per_plate: num_filled_wells_per_plate, - num_rows_per_well: num_rows_per_well, - study: study + num_plates:, + num_filled_wells_per_plate:, + num_rows_per_well:, + study: ) when /tube_library/, /tube_chromium_library/ FactoryBot.create(:sample_manifest, asset_type: 'library', study: study) @@ -236,7 +236,7 @@ def add_data # rubocop:todo Metrics/PerceivedComplexity, Metrics/MethodLength, Metrics/AbcSize def add_cell_data(column, row_num, partial) # rubocop:todo Metrics/CyclomaticComplexity if partial && empty_row?(row_num) - (data[column.name] || dynamic_attributes[row_num][column.name]) unless empty_columns.include?(column.name) + data[column.name] || dynamic_attributes[row_num][column.name] unless empty_columns.include?(column.name) elsif validation_errors.include?(:insert_size_from) && column.name == 'insert_size_from' && row_num == computed_first_row nil diff --git a/app/sequencescape_excel/sequencescape_excel/conditional_formatting_default.rb b/app/sequencescape_excel/sequencescape_excel/conditional_formatting_default.rb index 19f23f2623..c2ebb0e477 100644 --- a/app/sequencescape_excel/sequencescape_excel/conditional_formatting_default.rb +++ b/app/sequencescape_excel/sequencescape_excel/conditional_formatting_default.rb @@ -23,12 +23,12 @@ def expression? def combine(other = nil) (other || {}) - .merge(style: style, options: options) + .merge(style:, options:) .with_indifferent_access .tap do |cf| if expression? cf[:formula] ||= {} - cf[:formula].merge!(type: type) + cf[:formula].merge!(type:) end end end diff --git a/app/sequencescape_excel/sequencescape_excel/formula.rb b/app/sequencescape_excel/sequencescape_excel/formula.rb index d1cd7427da..be249aee3b 100644 --- a/app/sequencescape_excel/sequencescape_excel/formula.rb +++ b/app/sequencescape_excel/sequencescape_excel/formula.rb @@ -53,13 +53,7 @@ def to_s end def to_h - { - type: type, - first_cell_reference: first_cell_reference, - absolute_reference: absolute_reference, - operator: operator, - operand: operand - } + { type:, first_cell_reference:, absolute_reference:, operator:, operand: } end def inspect diff --git a/app/sequencescape_excel/sequencescape_excel/list.rb b/app/sequencescape_excel/sequencescape_excel/list.rb index be22382037..32890f3c36 100644 --- a/app/sequencescape_excel/sequencescape_excel/list.rb +++ b/app/sequencescape_excel/sequencescape_excel/list.rb @@ -104,8 +104,8 @@ def initialize ## # relates to each value i.e. each object that is added. - def each(&block) - values.each(&block) + def each(&) + values.each(&) end def values diff --git a/app/sequencescape_excel/sequencescape_excel/range.rb b/app/sequencescape_excel/sequencescape_excel/range.rb index 41b3adfcf9..601316b50e 100644 --- a/app/sequencescape_excel/sequencescape_excel/range.rb +++ b/app/sequencescape_excel/sequencescape_excel/range.rb @@ -136,12 +136,7 @@ def static? # Return a list of references which are generally used together in other # classes of the module. def references - { - first_cell_reference: first_cell_reference, - reference: reference, - fixed_reference: fixed_reference, - absolute_reference: absolute_reference - } + { first_cell_reference:, reference:, fixed_reference:, absolute_reference: } end private diff --git a/app/sequencescape_excel/sequencescape_excel/range_list.rb b/app/sequencescape_excel/sequencescape_excel/range_list.rb index 99312e88e9..9ef31cab36 100644 --- a/app/sequencescape_excel/sequencescape_excel/range_list.rb +++ b/app/sequencescape_excel/sequencescape_excel/range_list.rb @@ -19,8 +19,8 @@ def initialize(ranges_data = {}) @ranges = create(ranges_data) end - def each(&block) - ranges.each(&block) + def each(&) + ranges.each(&) end ## diff --git a/app/sequencescape_excel/sequencescape_excel/specialised_field/chromium_tag_well.rb b/app/sequencescape_excel/sequencescape_excel/specialised_field/chromium_tag_well.rb index 37645c2e4b..e44096aa41 100644 --- a/app/sequencescape_excel/sequencescape_excel/specialised_field/chromium_tag_well.rb +++ b/app/sequencescape_excel/sequencescape_excel/specialised_field/chromium_tag_well.rb @@ -21,7 +21,7 @@ def update(_attributes = {}) if asset.aliquots.one? tags.each { |tag| tag.multitag!(asset) } elsif aliquot_count == TAGS_PER_WELL - tags.zip(aliquots).each { |tag, aliquot| aliquot.assign_attributes(tag: tag) } + tags.zip(aliquots).each { |tag, aliquot| aliquot.assign_attributes(tag:) } else # We should never end up here, as our validation should handle this # However if that fails, something has gone wrong, and we shouldn't proceed diff --git a/app/sequencescape_excel/sequencescape_excel/specialised_field/dual_index_tag_well.rb b/app/sequencescape_excel/sequencescape_excel/specialised_field/dual_index_tag_well.rb index bfc58042a3..1d00f3d7df 100644 --- a/app/sequencescape_excel/sequencescape_excel/specialised_field/dual_index_tag_well.rb +++ b/app/sequencescape_excel/sequencescape_excel/specialised_field/dual_index_tag_well.rb @@ -28,7 +28,7 @@ def update(_attributes = {}) raise StandardError, 'Tag aliquot mismatch' unless asset.aliquots.one? # For dual index tags, tag is a i7 oligo and tag2 is a i5 oligo - asset.aliquots.first.update(tag: tag, tag2: tag2) + asset.aliquots.first.update(tag:, tag2:) end def link(other_fields) diff --git a/app/sequencescape_excel/sequencescape_excel/validation.rb b/app/sequencescape_excel/sequencescape_excel/validation.rb index ad0b7e0843..b49375bde6 100644 --- a/app/sequencescape_excel/sequencescape_excel/validation.rb +++ b/app/sequencescape_excel/sequencescape_excel/validation.rb @@ -85,7 +85,7 @@ def reference_start end def sanitized_options - options.merge(formula1: formula1) + options.merge(formula1:) end end end diff --git a/app/sequencescape_excel/sequencescape_excel/worksheet/base.rb b/app/sequencescape_excel/sequencescape_excel/worksheet/base.rb index 0a8944b244..e6848a2acc 100644 --- a/app/sequencescape_excel/sequencescape_excel/worksheet/base.rb +++ b/app/sequencescape_excel/sequencescape_excel/worksheet/base.rb @@ -50,7 +50,7 @@ def protect # Adds axlsx worksheet to a workbook, to a particular place. def insert_axlsx_worksheet(name, index = 0) - @axlsx_worksheet ||= workbook.insert_worksheet(index, name: name) # rubocop:disable Naming/MemoizedInstanceVariableName + @axlsx_worksheet ||= workbook.insert_worksheet(index, name:) # rubocop:disable Naming/MemoizedInstanceVariableName end # Creates a worksheet, empty one in this case diff --git a/app/uat_actions/uat_actions.rb b/app/uat_actions/uat_actions.rb index 07a3e587a9..e35a68821e 100644 --- a/app/uat_actions/uat_actions.rb +++ b/app/uat_actions/uat_actions.rb @@ -97,7 +97,7 @@ def form_field(attribute, type, options = {}) @form_fields ||= [] attr_accessor attribute - @form_fields << UatActions::FormField.new(options.merge(attribute: attribute, type: type)) + @form_fields << UatActions::FormField.new(options.merge(attribute:, type:)) end def form_fields diff --git a/app/uat_actions/uat_actions/generate_plate_concentrations.rb b/app/uat_actions/uat_actions/generate_plate_concentrations.rb index 10e138b9a5..ac97aacb5a 100644 --- a/app/uat_actions/uat_actions/generate_plate_concentrations.rb +++ b/app/uat_actions/uat_actions/generate_plate_concentrations.rb @@ -113,6 +113,6 @@ def construct_qc_assay num_wells_written += 1 end qc_assay_success = qc_assay.save - { qc_assay_success: qc_assay_success, num_wells_written: num_wells_written } + { qc_assay_success:, num_wells_written: } end end diff --git a/app/uat_actions/uat_actions/generate_plates.rb b/app/uat_actions/uat_actions/generate_plates.rb index 96ddd1329a..cde3b44858 100644 --- a/app/uat_actions/uat_actions/generate_plates.rb +++ b/app/uat_actions/uat_actions/generate_plates.rb @@ -146,7 +146,7 @@ def save_sample(sample, well, sample_index) if num_samples_per_well > 1 well.aliquots.create!(sample: sample, study: study, tag_depth: sample_index) else - well.aliquots.create!(sample: sample, study: study) + well.aliquots.create!(sample:, study:) end end diff --git a/app/uat_actions/uat_actions/generate_primer_panel.rb b/app/uat_actions/uat_actions/generate_primer_panel.rb index b2539ac3d8..4b5a947cbb 100644 --- a/app/uat_actions/uat_actions/generate_primer_panel.rb +++ b/app/uat_actions/uat_actions/generate_primer_panel.rb @@ -66,7 +66,7 @@ def perform # Any helper methods def existing_primer_panel - @existing_primer_panel ||= PrimerPanel.find_by(name: name) + @existing_primer_panel ||= PrimerPanel.find_by(name:) end def primer_panel_params diff --git a/app/uat_actions/uat_actions/generate_sample_manifest.rb b/app/uat_actions/uat_actions/generate_sample_manifest.rb index d28ed4020f..593993d515 100644 --- a/app/uat_actions/uat_actions/generate_sample_manifest.rb +++ b/app/uat_actions/uat_actions/generate_sample_manifest.rb @@ -60,7 +60,7 @@ def perform end def create_sample_manifest - SampleManifest.create!(study: study, supplier: supplier, asset_type: asset_type, count: count, purpose: purpose) + SampleManifest.create!(study:, supplier:, asset_type:, count:, purpose:) end def generate_manifest(sample_manifest) @@ -73,7 +73,7 @@ def create_samples(sample_manifest) raise 'Manifest for plates is not supported yet' unless asset_type == '1dtube' create_sample("Sample_#{asset.human_barcode}_1", sample_manifest).tap do |sample| - asset.aliquots.create!(sample: sample, study: study) + asset.aliquots.create!(sample:, study:) study.samples << sample end end diff --git a/app/uat_actions/uat_actions/generate_tag_group.rb b/app/uat_actions/uat_actions/generate_tag_group.rb index 8c0f0d206a..fc7790e751 100644 --- a/app/uat_actions/uat_actions/generate_tag_group.rb +++ b/app/uat_actions/uat_actions/generate_tag_group.rb @@ -90,7 +90,7 @@ def existing_tags # Any helper methods def existing_tag_group - @tag_group ||= TagGroup.find_by(name: name) + @tag_group ||= TagGroup.find_by(name:) end # diff --git a/app/uat_actions/uat_actions/generate_tag_layout_template.rb b/app/uat_actions/uat_actions/generate_tag_layout_template.rb index bf5559666d..339ab66cd6 100644 --- a/app/uat_actions/uat_actions/generate_tag_layout_template.rb +++ b/app/uat_actions/uat_actions/generate_tag_layout_template.rb @@ -72,7 +72,7 @@ def user end def existing_tag_layout_template - @existing_tag_layout_template ||= TagLayoutTemplate.find_by(name: name) + @existing_tag_layout_template ||= TagLayoutTemplate.find_by(name:) end def tag_group diff --git a/app/uat_actions/uat_actions/generate_tagged_plates.rb b/app/uat_actions/uat_actions/generate_tagged_plates.rb index 790f587fdc..07bda90818 100644 --- a/app/uat_actions/uat_actions/generate_tagged_plates.rb +++ b/app/uat_actions/uat_actions/generate_tagged_plates.rb @@ -70,16 +70,7 @@ def self.default end def perform - super do |plate| - TagLayout.create!( - user: user, - plate: plate, - direction: direction, - walking_by: walking_by, - tag_group: tag_group, - tag2_group: tag2_group - ) - end + super { |plate| TagLayout.create!(user:, plate:, direction:, walking_by:, tag_group:, tag2_group:) } end private diff --git a/app/uat_actions/uat_actions/test_submission.rb b/app/uat_actions/uat_actions/test_submission.rb index 0aafe6fbe6..d9fbece763 100644 --- a/app/uat_actions/uat_actions/test_submission.rb +++ b/app/uat_actions/uat_actions/test_submission.rb @@ -219,7 +219,7 @@ def order_request_options default_request_options.merge(custom_request_options) end - def default_request_options + def default_request_options # rubocop:todo Metrics/MethodLength submission_template .input_field_infos .each_with_object({}) do |ifi, options| diff --git a/app/uat_actions/uat_actions/tube_submission.rb b/app/uat_actions/uat_actions/tube_submission.rb index 35e7e506c9..db35dce31c 100644 --- a/app/uat_actions/uat_actions/tube_submission.rb +++ b/app/uat_actions/uat_actions/tube_submission.rb @@ -31,6 +31,26 @@ class UatActions::TubeSubmission < UatActions include_blank: 'Using default library type...' } + form_field :number_of_samples_per_pool, + :number_field, + label: 'Number of samples per pool', + help: + 'Optional field to set the number_of_samples_per_pool field on the ' \ + 'submission request. Leave blank if not required.', + options: { + minimum: 0 + } + + form_field :cells_per_chip_well, + :number_field, + label: 'Cells per Chip Well', + help: + 'Optional field to set the cells_per_chip_well field on the ' \ + 'submission request. Leave blank if not required.', + options: { + minimum: 0 + } + validates :submission_template, presence: { message: 'could not be found' } # Returns a default copy of the UatAction which will be used to fill in the form @@ -74,12 +94,21 @@ def perform # Fills the report with the information from the submission # # @return [Void] + # rubocop:disable Metrics/AbcSize def fill_report(order) report['tube_barcodes'] = assets.map(&:human_barcode) report['submission_id'] = order.submission.id report['library_type'] = order.request_options[:library_type] if order.request_options[:library_type].present? + report['number_of_samples_per_pool'] = order.request_options[:number_of_samples_per_pool] if order.request_options[ + :number_of_samples_per_pool + ].present? + report['cells_per_chip_well'] = order.request_options[:cells_per_chip_well] if order.request_options[ + :cells_per_chip_well + ].present? end + # rubocop:enable Metrics/AbcSize + # Returns the submisssion template to use for the submission # # @return [SubmissionTemplate] The submission template to use @@ -131,6 +160,8 @@ def default_request_options def custom_request_options options = {} options[:library_type] = library_type_name if library_type_name.present? + options[:number_of_samples_per_pool] = number_of_samples_per_pool.presence + options[:cells_per_chip_well] = cells_per_chip_well.presence options end diff --git a/app/uploaders/polymorphic_uploader.rb b/app/uploaders/polymorphic_uploader.rb index 6f067a5c55..3548e7f937 100644 --- a/app/uploaders/polymorphic_uploader.rb +++ b/app/uploaders/polymorphic_uploader.rb @@ -77,7 +77,7 @@ def destroy_file end class PolymorphicUploader < CarrierWave::Uploader::Base - def initialize(*args, &block) + def initialize(*args, &) super end diff --git a/app/views/batches/released.xml.builder b/app/views/batches/released.xml.builder index 8a764a2bb1..dbaeda68ad 100644 --- a/app/views/batches/released.xml.builder +++ b/app/views/batches/released.xml.builder @@ -7,7 +7,7 @@ xml.batches do |batches| batch.lanes do |lanes| count = 0 b.items.ordered.each do |item| - count = count + 1 + count += 1 lanes.lane('position' => count) do |lane| if item.resource? lane.control('id' => item.ident, 'name' => item.name, 'request_id' => item.request) diff --git a/app/views/samples/show.xml.builder b/app/views/samples/show.xml.builder index e3480fb9f8..dcf2fb68ee 100644 --- a/app/views/samples/show.xml.builder +++ b/app/views/samples/show.xml.builder @@ -28,7 +28,7 @@ xml.sample(api_data) do xml.property do # NOTE: The display text is targeted at HTML, so contains escaped entities, which we must unescape for XML. xml.name(REXML::Text.unnormalize(attribute.to_field_info.display_name)) - if (attribute.to_field_info.display_name == 'Reference Genome') && (value.blank?) + if (attribute.to_field_info.display_name == 'Reference Genome') && value.blank? xml.value(nil) else xml.value(value) diff --git a/app/views/studies/show.xml.builder b/app/views/studies/show.xml.builder index 0cc8551463..41e5ab6358 100644 --- a/app/views/studies/show.xml.builder +++ b/app/views/studies/show.xml.builder @@ -8,15 +8,14 @@ xml.study(api_data) do |study| %w[followers managers owners].each do |type_of_user| users, singular_user = @study.send(type_of_user), type_of_user.singularize - unless users.empty? - study.tag!(type_of_user) do |users_tag| - users.each do |user| - users_tag.tag!(singular_user) do |user_tag| - user_tag.login(user.login) - user_tag.email(user.email) - user_tag.name(user.name) - user_tag.id(user.id) - end + next if users.empty? + study.tag!(type_of_user) do |users_tag| + users.each do |user| + users_tag.tag!(singular_user) do |user_tag| + user_tag.login(user.login) + user_tag.email(user.email) + user_tag.name(user.name) + user_tag.id(user.id) end end end @@ -38,7 +37,7 @@ xml.study(api_data) do |study| @study.study_metadata.association_value_pairs.each do |attribute, value| descriptors.descriptor do |descriptor| descriptor.name(attribute.to_field_info.display_name) - if (attribute.to_field_info.display_name == 'Reference Genome') && (value.blank?) + if (attribute.to_field_info.display_name == 'Reference Genome') && value.blank? descriptor.value(nil) else descriptor.value(value) diff --git a/config/bulk_submission_excel/columns.yml b/config/bulk_submission_excel/columns.yml index b9ca72c5f9..dc9a63ab64 100644 --- a/config/bulk_submission_excel/columns.yml +++ b/config/bulk_submission_excel/columns.yml @@ -269,3 +269,43 @@ requested_flowcell_type: conditional_formattings: empty_cell: is_error: +number_of_samples_per_pool: + heading: scRNA Core Number of Samples per Pool + attribute: :number_of_samples_per_pool + unlocked: true + type: :integer + validation: + options: + type: :whole + operator: :between + formula1: "5" + formula2: "25" + allowBlank: true + showInputMessage: true + promptTitle: "Samples per Pool" + prompt: "The requested number of samples per pool (between 5 and 25 inclusive)" + conditional_formattings: + empty_cell: + is_text: + is_num_samples_per_pool_in_valid_range: + is_num_samples_per_pool_outside_valid_range: +cells_per_chip_well: + heading: scRNA Core Cells per Chip Well + attribute: :cells_per_chip_well + unlocked: true + type: :integer + validation: + options: + type: :whole + operator: :between + formula1: "12000" + formula2: "90000" + allowBlank: true + showInputMessage: true + promptTitle: "Cells per Chip Well" + prompt: "The number of cells per chip well (between 12,000 and 90,000 inclusive)" + conditional_formattings: + empty_cell: + is_text: + is_num_cells_per_chip_well_in_valid_range: + is_num_cells_per_chip_well_outside_valid_range: diff --git a/config/bulk_submission_excel/conditional_formattings.yml b/config/bulk_submission_excel/conditional_formattings.yml index 939fb024b0..4ce4122128 100644 --- a/config/bulk_submission_excel/conditional_formattings.yml +++ b/config/bulk_submission_excel/conditional_formattings.yml @@ -53,3 +53,43 @@ number_greater_than_one: operator: :lessThan formula: "1" priority: 2 +is_num_samples_per_pool_in_valid_range: + style: + bg_color: "00FF00" + type: :dxf + options: + type: :cellIs + operator: :between + formula1: "5" + formula2: "25" + priority: 2 +is_num_samples_per_pool_outside_valid_range: + style: + bg_color: "FF0000" + type: :dxf + options: + type: :cellIs + operator: :notBetween + formula1: "5" + formula2: "25" + priority: 2 +is_num_cells_per_chip_well_in_valid_range: + style: + bg_color: "00FF00" + type: :dxf + options: + type: :cellIs + operator: :between + formula1: "12000" + formula2: "90000" + priority: 2 +is_num_cells_per_chip_well_outside_valid_range: + style: + bg_color: "FF0000" + type: :dxf + options: + type: :cellIs + operator: :notBetween + formula1: "12000" + formula2: "90000" + priority: 2 diff --git a/config/default_records/plate_purposes/011_scrna_core_cdna_prep_plate_purposes.wip.yml b/config/default_records/plate_purposes/011_scrna_core_cdna_prep_plate_purposes.yml similarity index 100% rename from config/default_records/plate_purposes/011_scrna_core_cdna_prep_plate_purposes.wip.yml rename to config/default_records/plate_purposes/011_scrna_core_cdna_prep_plate_purposes.yml diff --git a/config/default_records/plate_purposes/013_lcm_triomics_plate_purposes.wip.yml b/config/default_records/plate_purposes/013_lcm_triomics_plate_purposes.wip.yml new file mode 100644 index 0000000000..d39b9b44d8 --- /dev/null +++ b/config/default_records/plate_purposes/013_lcm_triomics_plate_purposes.wip.yml @@ -0,0 +1,6 @@ +# Plate purposes for LCM Triomics WGS and EMSeq +--- +LCMT Lysate: + type: PlatePurpose::Input + stock_plate: true + cherrypickable_target: false diff --git a/config/default_records/product_catalogues/011_scrna_core_catalogue.wip.yml b/config/default_records/product_catalogues/011_scrna_core_catalogue.yml similarity index 100% rename from config/default_records/product_catalogues/011_scrna_core_catalogue.wip.yml rename to config/default_records/product_catalogues/011_scrna_core_catalogue.yml diff --git a/config/default_records/product_catalogues/013_lcm_triomics_catalogue.wip.yml b/config/default_records/product_catalogues/013_lcm_triomics_catalogue.wip.yml new file mode 100644 index 0000000000..6a36dcf6e5 --- /dev/null +++ b/config/default_records/product_catalogues/013_lcm_triomics_catalogue.wip.yml @@ -0,0 +1,3 @@ +--- +LCM Triomics: + selection_behaviour: SingleProduct diff --git a/config/default_records/request_types/014_limber_scrna_core_cdna_prep_request_types.wip.yml b/config/default_records/request_types/014_limber_scrna_core_cdna_prep_request_types.yml similarity index 96% rename from config/default_records/request_types/014_limber_scrna_core_cdna_prep_request_types.wip.yml rename to config/default_records/request_types/014_limber_scrna_core_cdna_prep_request_types.yml index 31c2f9352c..4c35b0b22a 100644 --- a/config/default_records/request_types/014_limber_scrna_core_cdna_prep_request_types.wip.yml +++ b/config/default_records/request_types/014_limber_scrna_core_cdna_prep_request_types.yml @@ -8,7 +8,7 @@ limber_scrna_core_cdna_prep_gem_x_5p: name: scRNA Core cDNA Prep GEM-X 5p asset_type: SampleTube order: 1 - request_class_name: CustomerRequest + request_class_name: PbmcPoolingCustomerRequest for_multiplexing: false billable: true product_line_name: Short Read diff --git a/config/default_records/request_types/015_limber_scrna_core_library_prep_request_types.wip.yml b/config/default_records/request_types/015_limber_scrna_core_library_prep_request_types.yml similarity index 100% rename from config/default_records/request_types/015_limber_scrna_core_library_prep_request_types.wip.yml rename to config/default_records/request_types/015_limber_scrna_core_library_prep_request_types.yml diff --git a/config/default_records/request_types/018_limber_lcm_triomics_request_types.wip.yml b/config/default_records/request_types/018_limber_lcm_triomics_request_types.wip.yml new file mode 100644 index 0000000000..66ce9a5260 --- /dev/null +++ b/config/default_records/request_types/018_limber_lcm_triomics_request_types.wip.yml @@ -0,0 +1,14 @@ +# Request types for LCM Triomics WGS and EMSeq +--- +limber_lcm_triomics_emseq: + name: LCM Triomics EMSeq + asset_type: Well + order: 1 + request_class_name: IlluminaHtp::Requests::StdLibraryRequest + for_multiplexing: false + billable: true + product_line_name: Short Read + acceptable_purposes: + - LCMT Lysate + library_types: + - LCM Triomics EMSeq diff --git a/config/default_records/submission_templates/011_scrna_core_cdna_prep_submission_templates.wip.yml b/config/default_records/submission_templates/011_scrna_core_cdna_prep_submission_templates.yml similarity index 100% rename from config/default_records/submission_templates/011_scrna_core_cdna_prep_submission_templates.wip.yml rename to config/default_records/submission_templates/011_scrna_core_cdna_prep_submission_templates.yml diff --git a/config/default_records/submission_templates/012_scrna_core_library_prep_submission_templates.wip.yml b/config/default_records/submission_templates/012_scrna_core_library_prep_submission_templates.yml similarity index 100% rename from config/default_records/submission_templates/012_scrna_core_library_prep_submission_templates.wip.yml rename to config/default_records/submission_templates/012_scrna_core_library_prep_submission_templates.yml diff --git a/config/default_records/submission_templates/014_lcm_triomics_submission_templates.wip.yml b/config/default_records/submission_templates/014_lcm_triomics_submission_templates.wip.yml new file mode 100644 index 0000000000..e1eece756c --- /dev/null +++ b/config/default_records/submission_templates/014_lcm_triomics_submission_templates.wip.yml @@ -0,0 +1,9 @@ +# Submission templates for LCM Triomics WGS and EMSeq +--- +# LCM Triomics EMSeq submission template +Limber-Htp - LCM Triomics EMSeq: + submission_class_name: "LinearSubmission" + related_records: + request_type_keys: ["limber_lcm_triomics_emseq"] + product_line_name: LCM Triomics + product_catalogue_name: LCM Triomics diff --git a/config/default_records/tube_purposes/008_scrna_core_cdna_prep_tube_purposes.wip.yml b/config/default_records/tube_purposes/008_scrna_core_cdna_prep_tube_purposes.yml similarity index 100% rename from config/default_records/tube_purposes/008_scrna_core_cdna_prep_tube_purposes.wip.yml rename to config/default_records/tube_purposes/008_scrna_core_cdna_prep_tube_purposes.yml diff --git a/config/initializers/api_routing.rb b/config/initializers/api_routing.rb index 26c900b4d5..1c711641e4 100644 --- a/config/initializers/api_routing.rb +++ b/config/initializers/api_routing.rb @@ -2,10 +2,10 @@ # TODO: Fix these module ApiRouting # Assets have a couple of extra actions that are always present: namely 'parents' and 'children' - def asset(*entities, &block) + def asset(*entities, &) options = entities.extract_options! entities.push({ member: { parents: :get, children: :get } }.merge(options)) - model(*entities, &block) + model(*entities, &) end # Models exposed through the API are assumed to always be read only, unless otherwise specified. Nested @@ -17,7 +17,7 @@ def model(*entities, &block) entities.push({ only: exposed_actions, name_prefix: 'api_' }.merge(options)) original_block = block - block = !block_given? ? original_block : ->(r) { r.with_options(read_only: read_only, &original_block) } + block = !block_given? ? original_block : ->(r) { r.with_options(read_only:, &original_block) } resources(*entities, &block) end end diff --git a/config/initializers/inflections.rb b/config/initializers/inflections.rb index 8e830495a5..e777bef7f3 100644 --- a/config/initializers/inflections.rb +++ b/config/initializers/inflections.rb @@ -11,7 +11,9 @@ # inflect.uncountable %w( fish sheep ) # end -ActiveSupport::Inflector.inflections(:en) { |inflect| inflect.uncountable %w[health sample_metadata labware] } +ActiveSupport::Inflector.inflections(:en) do |inflect| + inflect.uncountable %w[health sample_metadata request_metadata labware] +end # These inflection rules are supported but not enabled by default: # ActiveSupport::Inflector.inflections(:en) do |inflect| diff --git a/config/locales/metadata/en.yml b/config/locales/metadata/en.yml index d9ca5560aa..2abb785013 100644 --- a/config/locales/metadata/en.yml +++ b/config/locales/metadata/en.yml @@ -58,6 +58,12 @@ en: requested_flowcell_type: label: Flowcell type + number_of_samples_per_pool: + label: Number of samples per pool + + cells_per_chip_well: + label: Cells per chip well + library_creation_request: <<: *REQUEST sequencing_request: diff --git a/config/routes.rb b/config/routes.rb index 62092406f7..c4904fda43 100644 --- a/config/routes.rb +++ b/config/routes.rb @@ -21,6 +21,11 @@ jsonapi_resources :aliquots jsonapi_resources :assets jsonapi_resources :asset_audits + + jsonapi_resources :bait_library_layouts, except: %i[update] do + collection { post :preview } + end + jsonapi_resources :barcode_printers jsonapi_resources :comments jsonapi_resources :custom_metadatum_collections @@ -34,6 +39,7 @@ jsonapi_resources :plate_templates jsonapi_resources :plates jsonapi_resources :poly_metadata + jsonapi_resources :pooled_plate_creations, except: %i[update] jsonapi_resources :pre_capture_pools jsonapi_resources :primer_panels jsonapi_resources :projects @@ -43,11 +49,13 @@ jsonapi_resources :qcables jsonapi_resources :racked_tubes jsonapi_resources :receptacles + jsonapi_resources :request_metadata jsonapi_resources :request_types jsonapi_resources :requests jsonapi_resources :samples jsonapi_resources :sample_manifests jsonapi_resources :sample_metadata + jsonapi_resources :specific_tube_creations, except: %i[update] jsonapi_resources :state_changes, except: %i[update] jsonapi_resources :studies jsonapi_resources :submission_templates @@ -55,6 +63,7 @@ jsonapi_resources :tag_group_adapter_types jsonapi_resources :tag_groups jsonapi_resources :tag_layout_templates + jsonapi_resources :tag_layouts, except: %i[update] jsonapi_resources :tags jsonapi_resources :transfer_requests jsonapi_resources :transfer_templates diff --git a/db/migrate/20180328130539_populate_existing_purposes_with_prefix_data.rb b/db/migrate/20180328130539_populate_existing_purposes_with_prefix_data.rb index 30fa59a4ee..770fc54875 100644 --- a/db/migrate/20180328130539_populate_existing_purposes_with_prefix_data.rb +++ b/db/migrate/20180328130539_populate_existing_purposes_with_prefix_data.rb @@ -50,7 +50,7 @@ def up Purpose .where(target_type: asset_class) .find_each do |purpose| - purpose.barcode_prefix_id = BarcodePrefix.find_by(prefix: prefix).id + purpose.barcode_prefix_id = BarcodePrefix.find_by(prefix:).id purpose.save! end end diff --git a/db/migrate/20180329080953_remove_redundant_plate_classes.rb b/db/migrate/20180329080953_remove_redundant_plate_classes.rb index b8cdc493f8..e1fcececb8 100644 --- a/db/migrate/20180329080953_remove_redundant_plate_classes.rb +++ b/db/migrate/20180329080953_remove_redundant_plate_classes.rb @@ -35,7 +35,7 @@ def down Purpose .where(target_type: new_type) .joins('LEFT JOIN barcode_prefixes ON barcode_prefixes.id = plate_purposes.barcode_prefix_id') - .where(barcode_prefixes: { prefix: prefix }) + .where(barcode_prefixes: { prefix: }) .find_each do |purpose| purpose.target_type = original purpose.save diff --git a/db/migrate/20190522123113_migrate_plate_type_to_new_column.rb b/db/migrate/20190522123113_migrate_plate_type_to_new_column.rb index 2d5369599f..1db2be9ee6 100644 --- a/db/migrate/20190522123113_migrate_plate_type_to_new_column.rb +++ b/db/migrate/20190522123113_migrate_plate_type_to_new_column.rb @@ -31,7 +31,7 @@ def up .find_each do |asset| labware_type_id = LabwareType.id_for(asset.labware_type) say "Updating #{asset.id} => #{asset.labware_type} (#{labware_type_id})" - asset.update(labware_type_id: labware_type_id) + asset.update(labware_type_id:) end end end diff --git a/db/migrate/20190620094528_migrate_legacy_pipeline_classes.rb b/db/migrate/20190620094528_migrate_legacy_pipeline_classes.rb index 50b6d75348..d934f19d9c 100644 --- a/db/migrate/20190620094528_migrate_legacy_pipeline_classes.rb +++ b/db/migrate/20190620094528_migrate_legacy_pipeline_classes.rb @@ -30,10 +30,10 @@ def down ['Strip Tube Creation', 'StripTubeCreationPipeline'], ['HiSeq X PE (spiked in controls) from strip-tubes', 'UnrepeatableSequencingPipeline'] ].each do |name, sti_type| - pipeline = Pipeline.find_by(name: name) + pipeline = Pipeline.find_by(name:) next if pipeline.nil? - pipeline.update!(sti_type: sti_type) + pipeline.update!(sti_type:) end end end diff --git a/db/migrate/20211214094820_migrate_removed_pipelines_to_legacy_class.rb b/db/migrate/20211214094820_migrate_removed_pipelines_to_legacy_class.rb index 1600c56a4c..cff90c0429 100644 --- a/db/migrate/20211214094820_migrate_removed_pipelines_to_legacy_class.rb +++ b/db/migrate/20211214094820_migrate_removed_pipelines_to_legacy_class.rb @@ -32,10 +32,10 @@ def down %w[Genotyping GenotypingPipeline], ['Cherrypicking for Pulldown', 'CherrypickForPulldownPipeline'] ].each do |name, sti_type| - pipeline = Pipeline.find_by(name: name) + pipeline = Pipeline.find_by(name:) next if pipeline.nil? - pipeline.update!(sti_type: sti_type) + pipeline.update!(sti_type:) end end end diff --git a/db/migrate/20220428085815_remove_flexible_cherrypick_pipeline.rb b/db/migrate/20220428085815_remove_flexible_cherrypick_pipeline.rb index 30365a9b26..b597e44567 100644 --- a/db/migrate/20220428085815_remove_flexible_cherrypick_pipeline.rb +++ b/db/migrate/20220428085815_remove_flexible_cherrypick_pipeline.rb @@ -12,7 +12,7 @@ def down # The following code makes assumptions about names, and mimic the production # state when the migration was written. [['Flexible Cherrypick', 'FlexibleCherrypickPipeline']].each do |name, sti_type| - pipeline = Pipeline.find_by(name: name) + pipeline = Pipeline.find_by(name:) next if pipeline.nil? pipeline.update!(sti_type: sti_type, active: true) diff --git a/db/migrate/20240917133813_addsc_rna_fields_to_request_metadata.rb b/db/migrate/20240917133813_addsc_rna_fields_to_request_metadata.rb new file mode 100644 index 0000000000..551b12ffb4 --- /dev/null +++ b/db/migrate/20240917133813_addsc_rna_fields_to_request_metadata.rb @@ -0,0 +1,7 @@ +# frozen_string_literal: true +class AddscRnaFieldsToRequestMetadata < ActiveRecord::Migration[6.1] + def change + add_column :request_metadata, :number_of_samples_per_pool, :integer, null: true + add_column :request_metadata, :cells_per_chip_well, :integer, null: true + end +end diff --git a/db/schema.rb b/db/schema.rb index 207c08263d..682fe2630e 100644 --- a/db/schema.rb +++ b/db/schema.rb @@ -10,7 +10,7 @@ # # It's strongly recommended that you check this file into your version control system. -ActiveRecord::Schema.define(version: 2024_08_13_130010) do +ActiveRecord::Schema.define(version: 2024_09_17_133813) do create_table "aliquot_indices", id: :integer, charset: "utf8mb4", collation: "utf8mb4_unicode_ci", options: "ENGINE=InnoDB ROW_FORMAT=DYNAMIC", force: :cascade do |t| t.integer "aliquot_id", null: false @@ -1174,6 +1174,8 @@ t.string "data_type" t.integer "primer_panel_id" t.string "requested_flowcell_type" + t.integer "number_of_samples_per_pool" + t.integer "cells_per_chip_well" t.index ["request_id"], name: "index_request_metadata_on_request_id" end diff --git a/db/seeds/0001_workflows.rb b/db/seeds/0001_workflows.rb index df7018adff..e1a93b0d5b 100644 --- a/db/seeds/0001_workflows.rb +++ b/db/seeds/0001_workflows.rb @@ -175,7 +175,7 @@ def create_request_information_types(pipeline, *keys) per_item: false, lab_activity: true } - ].each { |details| details.delete(:class).create!(details.merge(workflow: workflow)) } + ].each { |details| details.delete(:class).create!(details.merge(workflow:)) } end end .tap do |pipeline| @@ -235,7 +235,7 @@ def create_request_information_types(pipeline, *keys) per_item: false, lab_activity: true } - ].each { |details| details.delete(:class).create!(details.merge(workflow: workflow)) } + ].each { |details| details.delete(:class).create!(details.merge(workflow:)) } end end .tap do |pipeline| @@ -288,7 +288,7 @@ def create_request_information_types(pipeline, *keys) per_item: false, lab_activity: true } - ].each { |details| details.delete(:class).create!(details.merge(workflow: workflow)) } + ].each { |details| details.delete(:class).create!(details.merge(workflow:)) } end end .tap do |pipeline| @@ -368,7 +368,7 @@ def create_request_information_types(pipeline, *keys) per_item: false, lab_activity: true } - ].each { |details| details.delete(:class).create!(details.merge(workflow: workflow)) } + ].each { |details| details.delete(:class).create!(details.merge(workflow:)) } end end .tap do |pipeline| @@ -424,7 +424,7 @@ def create_request_information_types(pipeline, *keys) per_item: false, lab_activity: true } - ].each { |details| details.delete(:class).create!(details.merge(workflow: workflow)) } + ].each { |details| details.delete(:class).create!(details.merge(workflow:)) } end end .tap do |pipeline| @@ -540,7 +540,7 @@ def create_request_information_types(pipeline, *keys) per_item: true, lab_activity: true } - ].each { |details| details.delete(:class).create!(details.merge(workflow: workflow)) } + ].each { |details| details.delete(:class).create!(details.merge(workflow:)) } end end .tap do |pipeline| @@ -585,7 +585,7 @@ def create_request_information_types(pipeline, *keys) per_item: true, lab_activity: true } - ].each { |details| details.delete(:class).create!(details.merge(workflow: workflow)) } + ].each { |details| details.delete(:class).create!(details.merge(workflow:)) } end end .tap { |pipeline| create_request_information_types(pipeline, 'read_length', 'library_type') } @@ -634,7 +634,7 @@ def create_request_information_types(pipeline, *keys) per_item: true, lab_activity: true } - ].each { |details| details.delete(:class).create!(details.merge(workflow: workflow)) } + ].each { |details| details.delete(:class).create!(details.merge(workflow:)) } end end .tap do |pipeline| @@ -689,7 +689,7 @@ def create_request_information_types(pipeline, *keys) per_item: true, lab_activity: true } - ].each { |details| details.delete(:class).create!(details.merge(workflow: workflow)) } + ].each { |details| details.delete(:class).create!(details.merge(workflow:)) } end end .tap do |pipeline| @@ -741,7 +741,7 @@ def create_request_information_types(pipeline, *keys) per_item: true, lab_activity: true } - ].each { |details| details.delete(:class).create!(details.merge(workflow: workflow)) } + ].each { |details| details.delete(:class).create!(details.merge(workflow:)) } end end .tap do |pipeline| @@ -792,7 +792,7 @@ def create_request_information_types(pipeline, *keys) per_item: false, lab_activity: true } - ].each { |details| details.delete(:class).create!(details.merge(workflow: workflow)) } + ].each { |details| details.delete(:class).create!(details.merge(workflow:)) } end end .tap do |pipeline| @@ -838,7 +838,7 @@ def create_request_information_types(pipeline, *keys) per_item: true, lab_activity: true } - ].each { |details| details.delete(:class).create!(details.merge(workflow: workflow)) } + ].each { |details| details.delete(:class).create!(details.merge(workflow:)) } end end .tap do |pipeline| @@ -911,7 +911,7 @@ def create_request_information_types(pipeline, *keys) per_item: true, lab_activity: true } - ].each { |details| details.delete(:class).create!(details.merge(workflow: workflow)) } + ].each { |details| details.delete(:class).create!(details.merge(workflow:)) } end end .tap do |pipeline| @@ -941,7 +941,7 @@ def create_request_information_types(pipeline, *keys) [ { class: PlateTemplateTask, name: 'Select Plate Template', sorted: 1, batched: true, lab_activity: true }, { class: CherrypickTask, name: 'Approve Plate Layout', sorted: 2, batched: true, lab_activity: true } - ].each { |details| details.delete(:class).create!(details.merge(workflow: workflow)) } + ].each { |details| details.delete(:class).create!(details.merge(workflow:)) } end end @@ -1232,7 +1232,7 @@ def create_request_information_types(pipeline, *keys) lab_activity: true } ].select { |task| type == '(spiked in controls)' || task[:name] != 'Add Spiked in Control' } - .each { |details| details.delete(:class).create!(details.merge(workflow: workflow)) } + .each { |details| details.delete(:class).create!(details.merge(workflow:)) } end pipeline.request_types = v4_requests_types_pe end @@ -1275,7 +1275,7 @@ def create_request_information_types(pipeline, *keys) lab_activity: true } ].select { |task| type == '(spiked in controls)' || task[:name] != 'Add Spiked in Control' } - .each { |details| details.delete(:class).create!(details.merge(workflow: workflow)) } + .each { |details| details.delete(:class).create!(details.merge(workflow:)) } end pipeline.request_types = v4_requests_types_se end @@ -1326,7 +1326,7 @@ def create_request_information_types(pipeline, *keys) lab_activity: true } ].select { |task| type == '(spiked in controls)' || task[:name] != 'Add Spiked in Control' } - .each { |details| details.delete(:class).create!(details.merge(workflow: workflow)) } + .each { |details| details.delete(:class).create!(details.merge(workflow:)) } end pipeline.request_types = x10_requests_types end diff --git a/db/seeds/0010_budget_division.rb b/db/seeds/0010_budget_division.rb index 3d0a1c3bdc..932143a57b 100644 --- a/db/seeds/0010_budget_division.rb +++ b/db/seeds/0010_budget_division.rb @@ -2,4 +2,4 @@ budget_divisions = ['Unallocated', 'Pathogen (including malaria)', 'Human variation'] -budget_divisions.each { |name| BudgetDivision.create!(name: name) } +budget_divisions.each { |name| BudgetDivision.create!(name:) } diff --git a/db/seeds/0013_reference_genome.rb b/db/seeds/0013_reference_genome.rb index baf13c1588..b0fec099ef 100644 --- a/db/seeds/0013_reference_genome.rb +++ b/db/seeds/0013_reference_genome.rb @@ -1,3 +1,3 @@ # frozen_string_literal: true -['', 'Not suitable for alignment'].each { |name| ReferenceGenome.create!(name: name) } +['', 'Not suitable for alignment'].each { |name| ReferenceGenome.create!(name:) } diff --git a/db/seeds/0016_tag_layout_templates.rb b/db/seeds/0016_tag_layout_templates.rb index bc4c58ffac..e5d76e8cce 100644 --- a/db/seeds/0016_tag_layout_templates.rb +++ b/db/seeds/0016_tag_layout_templates.rb @@ -58,12 +58,12 @@ 'TruSeq small RNA index tags - 6 mer tags', 'TruSeq mRNA Adapter Index Sequences' ].each do |name| - next if TagGroup.find_by(name: name).nil? + next if TagGroup.find_by(name:).nil? TagLayoutTemplate.create!( name: "Illumina C - #{name}", walking_algorithm: 'TagLayout::WalkWellsOfPlate', - tag_group: TagGroup.find_by(name: name), + tag_group: TagGroup.find_by(name:), direction_algorithm: 'TagLayout::InColumns' ) end diff --git a/db/seeds/0017_bait_libraries.rb b/db/seeds/0017_bait_libraries.rb index a9d76e8b7d..752f9a0893 100644 --- a/db/seeds/0017_bait_libraries.rb +++ b/db/seeds/0017_bait_libraries.rb @@ -3,7 +3,7 @@ # Generate a few bait libraries. { 'Standard' => 'standard', 'Custom - Pipeline' => 'custom', 'Custom - Customer' => 'custom' }.each do |name, category| - BaitLibraryType.create!(name: name, category: category) + BaitLibraryType.create!(name:, category:) end BaitLibrary::Supplier diff --git a/db/seeds/0019_plate_creators.rb b/db/seeds/0019_plate_creators.rb index 2a0541d2f6..098f126162 100644 --- a/db/seeds/0019_plate_creators.rb +++ b/db/seeds/0019_plate_creators.rb @@ -42,7 +42,7 @@ # Additional plate purposes required ['Pico dilution', 'Working dilution'].each do |name| - plate_purpose = PlatePurpose.find_by!(name: name) + plate_purpose = PlatePurpose.find_by!(name:) Plate::Creator.create!(name: name, plate_purposes: [plate_purpose]) end @@ -64,7 +64,7 @@ # Valid options: Dilution Factors: [['Working dilution', [12.5, 20.0, 15.0, 50.0]], ['Pico dilution', [4.0]]].each do |name, values| - c = Plate::Creator.find_by!(name: name) + c = Plate::Creator.find_by!(name:) c.update!(valid_options: { valid_dilution_factors: values }) end Plate::Creator.find_each do |c| diff --git a/db/seeds/3000_library_types_setup.rb b/db/seeds/3000_library_types_setup.rb index ded537a208..fafed9948e 100644 --- a/db/seeds/3000_library_types_setup.rb +++ b/db/seeds/3000_library_types_setup.rb @@ -154,7 +154,7 @@ def self.existing_defaults_for(request_type) 'Pre-quality controlled', 'DSN_RNAseq', 'RNA-seq dUTP' - ].map { |name| { name: name } } + ].map { |name| { name: } } ) RequestType.find_each do |request_type| @@ -228,7 +228,7 @@ def self.existing_defaults_for(request_type) 'Nextera single index pre quality controlled', 'Nextera dual index pre quality controlled', 'Bisulphate pre quality controlled' - ].map { |name| { name: name } } + ].map { |name| { name: } } ) %i[illumina_c_multiplexed_library_creation illumina_c_library_creation].each do |request_class_symbol| @@ -239,7 +239,7 @@ def self.existing_defaults_for(request_type) end libs_ribozero = - ['Ribozero RNA-seq (Bacterial)', 'Ribozero RNA-seq (HMR)'].map { |name| LibraryType.find_or_create_by!(name: name) } + ['Ribozero RNA-seq (Bacterial)', 'Ribozero RNA-seq (HMR)'].map { |name| LibraryType.find_or_create_by!(name:) } libs_ribozero.each do |lib| %i[illumina_c_pcr illumina_c_pcr_no_pool].each do |request_class_symbol| diff --git a/features/api/plate_creations.feature b/features/api/plate_creations.feature index b4ad4bd126..6d74b77e6f 100644 --- a/features/api/plate_creations.feature +++ b/features/api/plate_creations.feature @@ -12,7 +12,7 @@ Feature: Access plate creations through the API And the WTSI single sign-on service recognises "I-am-authenticated" as "John Smith" Given I am using the latest version of the API -And I have a "full" authorised user with the key "cucumber" + And I have a "full" authorised user with the key "cucumber" Given a user with UUID "99999999-8888-7777-6666-555555555555" exists diff --git a/features/support/barcode_service.rb b/features/support/barcode_service.rb index aa830d262b..c4666fbef0 100644 --- a/features/support/barcode_service.rb +++ b/features/support/barcode_service.rb @@ -30,7 +30,7 @@ def clear end def barcode(barcode, format = nil) - barcodes.push({ barcode: barcode, format: format }) + barcodes.push({ barcode:, format: }) end def next_barcode! diff --git a/features/support/cucumber_github_formatter.rb b/features/support/cucumber_github_formatter.rb index c18bff70bd..dacdcfa772 100644 --- a/features/support/cucumber_github_formatter.rb +++ b/features/support/cucumber_github_formatter.rb @@ -3,8 +3,8 @@ # This mostly comes from https://github.com/duderman/cucumber_github_formatter # but we patch puts to ensure we can use it with the progress formatter module CucumberGithubFormatter::Patch - def puts(*args) - super('', *args) + def puts(*) + super('', *) end end diff --git a/features/support/parameter_types.rb b/features/support/parameter_types.rb index a5755c89a2..7bfb0d9f72 100644 --- a/features/support/parameter_types.rb +++ b/features/support/parameter_types.rb @@ -14,14 +14,14 @@ name: 'plate_name', regexp: /the plate "([^"]+)"/, type: Plate, - transformer: ->(name) { Plate.find_by!(name: name) } + transformer: ->(name) { Plate.find_by!(name:) } ) ParameterType( name: 'asset_name', regexp: /the (plate|tube|sample tube|labware) "([^"]+)"/, type: Asset, - transformer: ->(_, name) { Labware.find_by!(name: name) } + transformer: ->(_, name) { Labware.find_by!(name:) } ) ParameterType( @@ -42,7 +42,7 @@ name: 'submitted_to', regexp: /submitted to "([^"]+)"/, type: SubmissionTemplate, - transformer: ->(name) { SubmissionTemplate.find_by!(name: name) } + transformer: ->(name) { SubmissionTemplate.find_by!(name:) } ) ParameterType( @@ -64,7 +64,7 @@ name: 'tag_layout_template', regexp: /tag layout template "([^"]+)"/, type: TagLayoutTemplate, - transformer: ->(name) { TagLayoutTemplate.find_by!(name: name) } + transformer: ->(name) { TagLayoutTemplate.find_by!(name:) } ) ParameterType( @@ -78,7 +78,7 @@ name: 'study_name', regexp: /the study "([^"]+)"/, type: Study, - transformer: ->(name) { Study.find_by!(name: name) } + transformer: ->(name) { Study.find_by!(name:) } ) ParameterType( @@ -115,5 +115,5 @@ name: 'asset_group', regexp: /the asset group "([^"]+)"/, type: AssetGroup, - transformer: ->(name) { AssetGroup.find_by!(name: name) } + transformer: ->(name) { AssetGroup.find_by!(name:) } ) diff --git a/features/support/paths.rb b/features/support/paths.rb index e77c5f2bb2..6cdd938d6d 100644 --- a/features/support/paths.rb +++ b/features/support/paths.rb @@ -4,7 +4,7 @@ module NavigationHelpers # Finds the specified page for the given model with the specified name. def page_for_model(model, page, name) - object = model.find_by!(name: name) + object = model.find_by!(name:) routing_method = "#{model.name.underscore}_path" routing_method = "#{page}_#{routing_method}" unless page == 'show' send(routing_method.to_sym, object) @@ -106,7 +106,7 @@ def path_to(page_name) # rubocop:todo Metrics/AbcSize study_reports_path when /the profile page for "([^"]+)"/ login = $1 - user = User.find_by!(login: login) + user = User.find_by!(login:) profile_path(user) when /the plate purpose homepage/ admin_plate_purposes_path diff --git a/features/support/step_definitions/10071597_change_request_type_on_request_steps.rb b/features/support/step_definitions/10071597_change_request_type_on_request_steps.rb index c8e663a79f..d5a91ed9dc 100644 --- a/features/support/step_definitions/10071597_change_request_type_on_request_steps.rb +++ b/features/support/step_definitions/10071597_change_request_type_on_request_steps.rb @@ -6,12 +6,14 @@ library_tube = FactoryBot.create :empty_library_tube request_type = RequestType.find_by(name: 'Illumina-B Paired end sequencing') request = - FactoryBot.create :request, - asset: library_tube, - target_asset: lane, - state: 'pending', - project: project, - request_type: request_type + FactoryBot.create( + :request, + asset: library_tube, + target_asset: lane, + state: 'pending', + project: project, + request_type: request_type + ) project.update!(enforce_quotas: true) end diff --git a/features/support/step_definitions/11803383_bug_NPG_batch_state_released_steps.rb b/features/support/step_definitions/11803383_bug_NPG_batch_state_released_steps.rb index a91894fffd..b4c79bacb2 100644 --- a/features/support/step_definitions/11803383_bug_NPG_batch_state_released_steps.rb +++ b/features/support/step_definitions/11803383_bug_NPG_batch_state_released_steps.rb @@ -11,7 +11,7 @@ request_type: pipeline.request_types.last, state: 'started' - batch = FactoryBot.create :batch, state: 'started', qc_state: 'qc_manual', pipeline: pipeline + batch = FactoryBot.create(:batch, state: 'started', qc_state: 'qc_manual', pipeline: pipeline) FactoryBot.create :batch_request, request: request, batch: batch, position: 1 end diff --git a/features/support/step_definitions/269135815_add_bait_library_editor_to_admin_view.rb b/features/support/step_definitions/269135815_add_bait_library_editor_to_admin_view.rb index ed41263014..fe0b2a8f9e 100644 --- a/features/support/step_definitions/269135815_add_bait_library_editor_to_admin_view.rb +++ b/features/support/step_definitions/269135815_add_bait_library_editor_to_admin_view.rb @@ -22,7 +22,7 @@ end Then /^the supplier_identifier for "([^"]*)" should be nil$/ do |name| - assert BaitLibrary.find_by(name: name).supplier_identifier.nil? + assert BaitLibrary.find_by(name:).supplier_identifier.nil? end Given /^I have a bait library type called "([^"]*)"$/ do |name| @@ -30,11 +30,11 @@ end Given /^I have a supplier called "([^"]*)"$/ do |name| - BaitLibrary::Supplier.create!(name: name) + BaitLibrary::Supplier.create!(name:) end Then /^the "([^"]*)" called "([^"]*)" should exist$/ do |class_name, name| - matching = class_name.constantize.find_by(name: name) + matching = class_name.constantize.find_by(name:) assert matching end @@ -43,7 +43,7 @@ end Given /^the last bait library has supplier "([^"]*)"$/ do |name| - BaitLibrary.last.update(bait_library_supplier: BaitLibrary::Supplier.create!(name: name)) + BaitLibrary.last.update(bait_library_supplier: BaitLibrary::Supplier.create!(name:)) end Given /^the last bait library is hidden$/ do diff --git a/features/support/step_definitions/35177179_updating_released_samples_steps.rb b/features/support/step_definitions/35177179_updating_released_samples_steps.rb index 6b71b20e6b..1a372ae3ca 100644 --- a/features/support/step_definitions/35177179_updating_released_samples_steps.rb +++ b/features/support/step_definitions/35177179_updating_released_samples_steps.rb @@ -1,11 +1,11 @@ # frozen_string_literal: true Given /^the sample name "([^"]*)" has previously been released$/ do |name| - Sample.find_by(name: name).release + Sample.find_by(name:).release end When /^ignoring "([^"]+)" the XML submission for the sample "([^"]*)" should be:$/ do |key_regexp, name, serialized_xml| - sample = Sample.find_by(name: name) or raise StandardError, "Cannot find sample with name #{name.inspect}" + sample = Sample.find_by(name:) or raise StandardError, "Cannot find sample with name #{name.inspect}" accession_service = sample.accession_service accessionable_sample = Accessionable::Sample.new(sample) submission = Accessionable::Submission.new(accession_service, User.find_by(login: 'me'), accessionable_sample) diff --git a/features/support/step_definitions/3550676_search_functionality_steps.rb b/features/support/step_definitions/3550676_search_functionality_steps.rb index b70bdaef65..a164931617 100644 --- a/features/support/step_definitions/3550676_search_functionality_steps.rb +++ b/features/support/step_definitions/3550676_search_functionality_steps.rb @@ -4,7 +4,7 @@ sample = Sample.find_by(name: sample_name) or raise StandardError, "Could not find a sample named '#{sample_name}'" FactoryBot .create(:empty_sample_tube, name: sample_tube_name) - .tap { |sample_tube| sample_tube.aliquots.create!(sample: sample) } + .tap { |sample_tube| sample_tube.aliquots.create!(sample:) } end Then /^the search results I should see are:$/ do |table| diff --git a/features/support/step_definitions/3871492_links_from_study_workflow_view_steps.rb b/features/support/step_definitions/3871492_links_from_study_workflow_view_steps.rb index 499b61141e..87afa5c725 100644 --- a/features/support/step_definitions/3871492_links_from_study_workflow_view_steps.rb +++ b/features/support/step_definitions/3871492_links_from_study_workflow_view_steps.rb @@ -3,7 +3,7 @@ Given /^study "([^"]+)" has a registered sample "([^"]+)"$/ do |study_name, sample_name| study = Study.find_by!(name: study_name) sample = study.samples.create!(name: sample_name) - st = SampleTube.create!.tap { |sample_tube| sample_tube.aliquots.create!(sample: sample, study: study) } + st = SampleTube.create!.tap { |sample_tube| sample_tube.aliquots.create!(sample:, study:) } FactoryHelp.submission(study: study, assets: [st], state: 'ready') end diff --git a/features/support/step_definitions/3958121_sample_update_filters_properties_steps.rb b/features/support/step_definitions/3958121_sample_update_filters_properties_steps.rb index b51dfb7796..7b692e26f7 100644 --- a/features/support/step_definitions/3958121_sample_update_filters_properties_steps.rb +++ b/features/support/step_definitions/3958121_sample_update_filters_properties_steps.rb @@ -1,7 +1,7 @@ # frozen_string_literal: true Given /^I am the owner of sample "([^"]+)"$/ do |name| - sample = Sample.find_by!(name: name) + sample = Sample.find_by!(name:) @current_user.grant_owner(sample) end diff --git a/features/support/step_definitions/4560014_refactoring_properties_descriptors_etc_to_table_columns_steps.rb b/features/support/step_definitions/4560014_refactoring_properties_descriptors_etc_to_table_columns_steps.rb index 1958f2a060..a4b0c6a358 100644 --- a/features/support/step_definitions/4560014_refactoring_properties_descriptors_etc_to_table_columns_steps.rb +++ b/features/support/step_definitions/4560014_refactoring_properties_descriptors_etc_to_table_columns_steps.rb @@ -7,13 +7,7 @@ def create_request(request_type, study, project, asset, target_asset, additional request = FactoryBot.create( :request_with_submission, - additional_options.merge( - study: study, - project: project, - asset: asset, - target_asset: target_asset, - request_type: request_type - ) + additional_options.merge(study:, project:, asset:, target_asset:, request_type:) ) request.id = additional_options[:id] if additional_options.key?(:id) # Force ID hack! diff --git a/features/support/step_definitions/5070230_requesting_additional_hiseq_sequencing_steps.rb b/features/support/step_definitions/5070230_requesting_additional_hiseq_sequencing_steps.rb index 7b8c94b853..46f447046c 100644 --- a/features/support/step_definitions/5070230_requesting_additional_hiseq_sequencing_steps.rb +++ b/features/support/step_definitions/5070230_requesting_additional_hiseq_sequencing_steps.rb @@ -3,7 +3,7 @@ Given 'I have already made a request for library tube {string} within {study_name}' do |library_tube_name, study| library_tube = LibraryTube.find_by!(name: library_tube_name) library_type = LibraryType.find_by(name: 'Standard') || FactoryBot.create(:library_type, name: 'Standard') - FactoryBot.create(:library_creation_request_type, :with_library_types, library_type: library_type).create!( + FactoryBot.create(:library_creation_request_type, :with_library_types, library_type:).create!( asset: library_tube, study: study, request_metadata_attributes: { diff --git a/features/support/step_definitions/5158172_gel_hide_blank_wells_steps.rb b/features/support/step_definitions/5158172_gel_hide_blank_wells_steps.rb index 9f3ee65df0..cdfdfccf17 100644 --- a/features/support/step_definitions/5158172_gel_hide_blank_wells_steps.rb +++ b/features/support/step_definitions/5158172_gel_hide_blank_wells_steps.rb @@ -18,7 +18,7 @@ # This may be forcing the name of the sample so we cannot check validation here. sample = Sample.new(name: sample_name) sample.save(validate: false) - well.aliquots.create!(sample: sample) + well.aliquots.create!(sample:) end Given /^well "([^"]*)" on plate "([^"]*)" has an empty supplier sample name$/ do |well_position, plate_barcode| diff --git a/features/support/step_definitions/5393882_spiked_in_control_steps.rb b/features/support/step_definitions/5393882_spiked_in_control_steps.rb index 39bc795ae2..70fabf2eb6 100644 --- a/features/support/step_definitions/5393882_spiked_in_control_steps.rb +++ b/features/support/step_definitions/5393882_spiked_in_control_steps.rb @@ -1,7 +1,7 @@ # frozen_string_literal: true Given /^I have a hybridization spiked buffer called "([^"]+)"$/ do |name| - buffer = FactoryBot.create(:spiked_buffer, name: name) + buffer = FactoryBot.create(:spiked_buffer, name:) buffer.parents << FactoryBot.create(:phi_x_stock_tube, name: 'indexed phiX') end @@ -17,6 +17,6 @@ end Then /^(.+) asset (?:called|named) "([^"]+)"(.*)$/ do |pre, name, post| - asset = Labware.find_by(name: name) or raise StandardError, "Cannot find asset #{name.inspect}" + asset = Labware.find_by(name:) or raise StandardError, "Cannot find asset #{name.inspect}" step "#{pre} asset \"#{asset.id}\"#{post}" end diff --git a/features/support/step_definitions/5397680_sequenome_plate_details_steps.rb b/features/support/step_definitions/5397680_sequenome_plate_details_steps.rb index 6a71a1c27b..a67119482f 100644 --- a/features/support/step_definitions/5397680_sequenome_plate_details_steps.rb +++ b/features/support/step_definitions/5397680_sequenome_plate_details_steps.rb @@ -10,7 +10,7 @@ sample = FactoryBot.create :sample_with_gender, name: "#{plate_barcode}_x" - 1.upto(number_of_wells.to_i) { |i| new_plate.wells.create!(map_id: i).aliquots.create!(sample: sample) } + 1.upto(number_of_wells.to_i) { |i| new_plate.wells.create!(map_id: i).aliquots.create!(sample:) } end Given(/^plate "([^"]*)" has (\d+) blank samples$/) do |plate_barcode, number_of_blanks| diff --git a/features/support/step_definitions/5781572_external_data_release_interactions_steps.rb b/features/support/step_definitions/5781572_external_data_release_interactions_steps.rb index 91547d10d1..e144d8ca3c 100644 --- a/features/support/step_definitions/5781572_external_data_release_interactions_steps.rb +++ b/features/support/step_definitions/5781572_external_data_release_interactions_steps.rb @@ -5,13 +5,13 @@ end Given /^an unreleasable lane named "([^"]*)"$/ do |name| - lane = Lane.joins(:labware).find_by(labware: { name: name }) + lane = Lane.joins(:labware).find_by(labware: { name: }) lane.external_release = false lane.save end Given /^an releasable lane named "([^"]*)"$/ do |name| - lane = Lane.joins(:labware).find_by(labware: { name: name }) + lane = Lane.joins(:labware).find_by(labware: { name: }) lane.external_release = true lane.save end diff --git a/features/support/step_definitions/6218053_display_concentration_inbox_pipeline_steps.rb b/features/support/step_definitions/6218053_display_concentration_inbox_pipeline_steps.rb index d6192a9ad4..fae396e947 100644 --- a/features/support/step_definitions/6218053_display_concentration_inbox_pipeline_steps.rb +++ b/features/support/step_definitions/6218053_display_concentration_inbox_pipeline_steps.rb @@ -1,7 +1,7 @@ # frozen_string_literal: true Given /^Pipeline "([^"]*)" and a setup for 6218053$/ do |name| - pipeline = Pipeline.find_by(name: name) or raise StandardError, "Cannot find pipeline '#{name}'" + pipeline = Pipeline.find_by(name:) or raise StandardError, "Cannot find pipeline '#{name}'" asset_type = pipeline_name_to_asset_type(name) request_type = pipeline.request_types.detect { |rt| !rt.deprecated } metadata = FactoryBot.create :"request_metadata_for_#{request_type.key}" diff --git a/features/support/step_definitions/641709_create_duplicate_SE_pipeline_with_no_controls_steps.rb b/features/support/step_definitions/641709_create_duplicate_SE_pipeline_with_no_controls_steps.rb index bf6b88c5a2..5979ff4eb5 100644 --- a/features/support/step_definitions/641709_create_duplicate_SE_pipeline_with_no_controls_steps.rb +++ b/features/support/step_definitions/641709_create_duplicate_SE_pipeline_with_no_controls_steps.rb @@ -1,7 +1,7 @@ # frozen_string_literal: true Given /^Pipeline "([^"]*)" and a setup for 641709$/ do |name| - pipeline = Pipeline.find_by(name: name) or raise StandardError, "Cannot find pipeline '#{name}'" + pipeline = Pipeline.find_by(name:) or raise StandardError, "Cannot find pipeline '#{name}'" pipeline.workflow.item_limit.times { step("I have a request for \"#{name}\"") } end diff --git a/features/support/step_definitions/65192392_tag_qc_steps.rb b/features/support/step_definitions/65192392_tag_qc_steps.rb index b4dc423899..51c84f9a5c 100644 --- a/features/support/step_definitions/65192392_tag_qc_steps.rb +++ b/features/support/step_definitions/65192392_tag_qc_steps.rb @@ -17,7 +17,7 @@ end Given /^the UUID for the lot type "(.*?)" is "(.*?)"$/ do |name, uuid| - set_uuid_for(LotType.find_by(name: name), uuid) + set_uuid_for(LotType.find_by(name:), uuid) end Given /^the lot exists with the attributes:$/ do |table| @@ -33,20 +33,20 @@ end Given /^the UUID for the lot with lot number "(.*?)" is "(.*?)"$/ do |lot_number, uuid| - set_uuid_for(Lot.find_by(lot_number: lot_number), uuid) + set_uuid_for(Lot.find_by(lot_number:), uuid) end Given /^lot "(.*?)" has (\d+) created qcables$/ do |lot_number, qcable_count| - lot = Lot.find_by(lot_number: lot_number) + lot = Lot.find_by(lot_number:) QcableCreator.create!(lot: lot, user: User.last, count: qcable_count.to_i) end Then /^the qcables in lot "(.*?)" should be "(.*?)"$/ do |lot_number, target_state| - Lot.find_by(lot_number: lot_number).qcables.each { |qcable| assert_equal target_state, qcable.state } + Lot.find_by(lot_number:).qcables.each { |qcable| assert_equal target_state, qcable.state } end Given /^all qcables in lot "(.*?)" are "(.*?)"$/ do |lot_number, state| - Lot.find_by(lot_number: lot_number).qcables.each { |qcable| qcable.update!(state: state) } + Lot.find_by(lot_number:).qcables.each { |qcable| qcable.update!(state:) } end Given /^I am set up for testing qcable ordering$/ do diff --git a/features/support/step_definitions/6679401_batch_request_recycling_broken_steps.rb b/features/support/step_definitions/6679401_batch_request_recycling_broken_steps.rb index 3ab8138ca3..794cfdea02 100644 --- a/features/support/step_definitions/6679401_batch_request_recycling_broken_steps.rb +++ b/features/support/step_definitions/6679401_batch_request_recycling_broken_steps.rb @@ -29,7 +29,7 @@ end Given /^the plate template "([^"]+)" exists$/ do |name| - FactoryBot.create(:plate_template, name: name) + FactoryBot.create(:plate_template, name:) end # This is a complete hack to get this to work: it knows where the wells are and goes to get them. It knows @@ -51,7 +51,7 @@ ######################################################################################################### # rubocop:todo Metrics/MethodLength def build_batch_for(name, count) # rubocop:todo Metrics/AbcSize - pipeline = Pipeline.find_by(name: name) or raise StandardError, "Cannot find pipeline #{name.inspect}" + pipeline = Pipeline.find_by(name:) or raise StandardError, "Cannot find pipeline #{name.inspect}" submission_details = yield(pipeline) user = FactoryBot.create(:user) @@ -91,12 +91,12 @@ def build_batch_for(name, count) # rubocop:todo Metrics/AbcSize raise StandardError, "Pipeline has #{requests.size} requests waiting rather than #{count}" end - batch = Batch.create!(pipeline: pipeline, user: user, requests: requests) + batch = Batch.create!(pipeline:, user:, requests:) end # rubocop:enable Metrics/MethodLength def requests_for_pipeline(name, count) - pipeline = Pipeline.find_by(name: name) or raise StandardError, "Cannot find pipeline #{name.inspect}" + pipeline = Pipeline.find_by(name:) or raise StandardError, "Cannot find pipeline #{name.inspect}" requests_in_inbox = pipeline.requests.ready_in_storage.full_inbox.all # There should be requests in the inbox and they should be clones of original requests. diff --git a/features/support/step_definitions/aliquot_steps.rb b/features/support/step_definitions/aliquot_steps.rb index 85b52fafc4..fa61b0523d 100644 --- a/features/support/step_definitions/aliquot_steps.rb +++ b/features/support/step_definitions/aliquot_steps.rb @@ -21,7 +21,7 @@ def assert_equal_aliquots(expected, received) end Given /^the aliquots in the library tube called "([^"]+)" have been modified$/ do |name| - tube = LibraryTube.find_by(name: name) or raise "Can't find library tube named #{name.inspect}" + tube = LibraryTube.find_by(name:) or raise "Can't find library tube named #{name.inspect}" tube.aliquots.each do |a| a.updated_at = Time.zone.now a.save(validate: false) diff --git a/features/support/step_definitions/api_steps.rb b/features/support/step_definitions/api_steps.rb index 94254d3454..2a6ed03f95 100644 --- a/features/support/step_definitions/api_steps.rb +++ b/features/support/step_definitions/api_steps.rb @@ -27,10 +27,10 @@ def recursive_diff(h1, h2) # rubocop:todo Metrics/CyclomaticComplexity end # rubocop:enable Metrics/AbcSize, Metrics/MethodLength, Metrics/PerceivedComplexity -def assert_hash_equal(h1, h2, *args) +def assert_hash_equal(h1, h2, *) d1 = recursive_diff(h1, h2) d2 = recursive_diff(h2, h1) - assert_equal(d1, d2, *args) + assert_equal(d1, d2, *) end def walk_hash_structure(hash_data, &block) @@ -46,10 +46,10 @@ def walk_hash_structure(hash_data, &block) end end -def assert_json_equal(expected, received, &block) +def assert_json_equal(expected, received, &) assert_hash_equal( - walk_hash_structure(decode_json(expected, 'Expected'), &block), - walk_hash_structure(decode_json(received, 'Received'), &block), + walk_hash_structure(decode_json(expected, 'Expected'), &), + walk_hash_structure(decode_json(received, 'Received'), &), 'Differs when decoded' ) end @@ -64,7 +64,7 @@ def assert_json_equal(expected, received, &block) end Given /^the WTSI single sign-on service recognises "([^"]+)" as "([^"]+)"$/ do |key, login| - User.find_or_create_by(login: login).update!(api_key: key) + User.find_or_create_by(login:).update!(api_key: key) end Given /^the WTSI single sign-on service does not recognise "([^"]+)"$/ do |cookie| @@ -92,28 +92,28 @@ def api_request(action, path, body) # rubocop:todo Metrics/AbcSize step("I am using version \"#{Core::Service::API_VERSION}\" of the API") end -When %r{^I (GET|PUT|POST|DELETE) the API path "(\/[^"]*)"$} do |action, path| +When %r{^I (GET|PUT|POST|DELETE) the API path "(/[^"]*)"$} do |action, path| api_request(action, path, nil) end -When %r{^I (POST|PUT) the following JSON to the API path "(\/[^"]*)":$} do |action, path, serialized_json| +When %r{^I (POST|PUT) the following JSON to the API path "(/[^"]*)":$} do |action, path, serialized_json| api_request(action, path, serialized_json) end -When %r{^I GET the "([^"]+)" from the API path "(\/[^"]*)"$} do |content_type, path| +When %r{^I GET the "([^"]+)" from the API path "(/[^"]*)"$} do |content_type, path| api_request('GET', path, nil) { |headers| headers.merge!('HTTP_ACCEPT' => content_type) } end -When %r{^I (POST|PUT) the following "([^"]+)" to the API path "(\/[^"]*)":$} do |action, content_type, path, body| +When %r{^I (POST|PUT) the following "([^"]+)" to the API path "(/[^"]*)":$} do |action, content_type, path, body| api_request(action, path, body) { |headers| headers.merge!('CONTENT_TYPE' => content_type) } end -When %r{^I make an authorised (GET|DELETE) (?:(?:for|of) )?the API path "(\/[^"]*)"$} do |action, path| +When %r{^I make an authorised (GET|DELETE) (?:(?:for|of) )?the API path "(/[^"]*)"$} do |action, path| api_request(action, path, nil) { |headers| headers['HTTP_X_SEQUENCESCAPE_CLIENT_ID'] = 'cucumber' } end # rubocop:todo Layout/LineLength -When %r{^I make an authorised (POST|PUT) with the following JSON to the API path "(\/[^"]*)":$} do |action, path, serialized_json| +When %r{^I make an authorised (POST|PUT) with the following JSON to the API path "(/[^"]*)":$} do |action, path, serialized_json| # rubocop:enable Layout/LineLength api_request(action, path, serialized_json) { |headers| headers['HTTP_X_SEQUENCESCAPE_CLIENT_ID'] = 'cucumber' } end @@ -127,18 +127,18 @@ def api_request(action, path, body) # rubocop:todo Metrics/AbcSize end When /^I retrieve the JSON for all requests related to the (sample|library) tube "([^"]+)"$/ do |tube_type, name| - tube = "#{tube_type}_tube".classify.constantize.find_by(name: name) or + tube = "#{tube_type}_tube".classify.constantize.find_by(name:) or raise StandardError, "Cannot find #{tube_type} tube called #{name.inspect}" visit(url_for(controller: 'api/requests', action: 'index', "#{tube_type}_tube_id": tube.id, format: :json)) end When /^I retrieve the JSON for the (sample|study) "([^"]+)"$/ do |model, name| - object = model.classify.constantize.find_by(name: name) or raise "Cannot find #{model} #{name.inspect}" + object = model.classify.constantize.find_by(name:) or raise "Cannot find #{model} #{name.inspect}" visit(url_for(controller: "api/#{model.pluralize}", action: 'show', id: object, format: :json)) end When /^I retrieve the JSON for the last request in the study "([^"]+)"$/ do |name| - study = Study.find_by(name: name) or raise StandardError, "Cannot find the study #{name.inspect}" + study = Study.find_by(name:) or raise StandardError, "Cannot find the study #{name.inspect}" raise StandardError, "It appears there are no requests for study #{name.inspect}" if study.requests.empty? visit(url_for(controller: 'api/requests', action: 'show', id: study.requests.last, format: :json)) @@ -283,11 +283,11 @@ def decode_json(json, source) end Given /^the sample "([^"]+)" is in (\d+) sample tubes? with sequential IDs starting at (\d+)$/ do |name, count, base_id| - sample = Sample.find_by(name: name) or raise StandardError, "Cannot find the sample #{name.inspect}" + sample = Sample.find_by(name:) or raise StandardError, "Cannot find the sample #{name.inspect}" (1..count.to_i).each do |index| FactoryBot .create(:empty_sample_tube, name: "#{name} sample tube #{index}", id: (base_id.to_i + index - 1)) - .tap { |sample_tube| sample_tube.aliquots.create!(sample: sample) } + .tap { |sample_tube| sample_tube.aliquots.create!(sample:) } end end diff --git a/features/support/step_definitions/asset_steps.rb b/features/support/step_definitions/asset_steps.rb index 92c452cf92..1b76b0a837 100644 --- a/features/support/step_definitions/asset_steps.rb +++ b/features/support/step_definitions/asset_steps.rb @@ -1,22 +1,22 @@ # frozen_string_literal: true Given /^the barcode for the sample tube "([^"]+)" is "([^"]+)"$/ do |name, barcode| - sample_tube = SampleTube.find_by!(name: name) - sample_tube.primary_barcode.update!(barcode: barcode) + sample_tube = SampleTube.find_by!(name:) + sample_tube.primary_barcode.update!(barcode:) end Given /^the barcode for the asset "([^"]+)" is "([^"]+)"$/ do |name, barcode| - Barcode.find_by(barcode: barcode)&.destroy - asset = Labware.find_by!(name: name) + Barcode.find_by(barcode:)&.destroy + asset = Labware.find_by!(name:) if asset.primary_barcode - asset.primary_barcode.update!(barcode: barcode) + asset.primary_barcode.update!(barcode:) else - asset.barcodes << FactoryBot.create(:sanger_ean13_tube, barcode: barcode) + asset.barcodes << FactoryBot.create(:sanger_ean13_tube, barcode:) end end Given /^tube "([^"]*)" has a public name of "([^"]*)"$/ do |name, public_name| - Labware.find_by(name: name).update!(public_name: public_name) + Labware.find_by(name:).update!(public_name:) end Given /^(?:I have )?a phiX tube called "([^"]+)"$/ do |name| @@ -24,11 +24,11 @@ end Given /^(?:I have )?a (sample|library) tube called "([^"]+)"$/ do |tube_type, name| - FactoryBot.create(:"#{tube_type}_tube", name: name) + FactoryBot.create(:"#{tube_type}_tube", name:) end Given 'I have an empty library tube called {string}' do |name| - FactoryBot.create(:empty_library_tube, name: name) + FactoryBot.create(:empty_library_tube, name:) end Then 'the name of {uuid} should be {string}' do |asset, name| diff --git a/features/support/step_definitions/authentication_steps.rb b/features/support/step_definitions/authentication_steps.rb index edd9bb252c..b5661ad03e 100644 --- a/features/support/step_definitions/authentication_steps.rb +++ b/features/support/step_definitions/authentication_steps.rb @@ -33,11 +33,11 @@ end Then /^I should be logged in as "([^"]*)"$/ do |login| - user = User.find_by(login: login) + user = User.find_by(login:) assert @current_user == user end Given /^user "([^"]*)" has nil first and last names$/ do |login| - user = User.find_by(login: login) + user = User.find_by(login:) user.update!(last_name: nil, first_name: nil) end diff --git a/features/support/step_definitions/bait_library_steps.rb b/features/support/step_definitions/bait_library_steps.rb index 2bd0559590..687c3686e0 100644 --- a/features/support/step_definitions/bait_library_steps.rb +++ b/features/support/step_definitions/bait_library_steps.rb @@ -5,7 +5,7 @@ end Then 'the bait library for {well_range} of {plate_name} should be {string}' do |range, plate, name| - bait_library = BaitLibrary.find_by(name: name) or raise StandardError, "Cannot find bait library #{name.inspect}" + bait_library = BaitLibrary.find_by(name:) or raise StandardError, "Cannot find bait library #{name.inspect}" bait_libraries = plate.wells.select(&range.method(:include?)).map(&:aliquots).flatten.map(&:bait_library).uniq assert_equal([bait_library], bait_libraries, 'The bait libraries do not match what was expected') end diff --git a/features/support/step_definitions/batch_steps.rb b/features/support/step_definitions/batch_steps.rb index 1dd53f6781..624e1fd573 100644 --- a/features/support/step_definitions/batch_steps.rb +++ b/features/support/step_definitions/batch_steps.rb @@ -17,13 +17,13 @@ Given /^the last batch is for the "([^"]+)" pipeline$/ do |name| batch = Batch.last or raise StandardError, 'There appear to be no batches' - pipeline = Pipeline.find_by(name: name) or raise StandardError, "Unable to find the pipeline #{name}" + pipeline = Pipeline.find_by(name:) or raise StandardError, "Unable to find the pipeline #{name}" pipeline.batches << batch end Given /^"([^"]+)" is the owner of batch with ID (\d+)$/ do |login, id| - user = User.find_by(login: login) or raise StandardError, "Cannot find user login #{login.inspect}" - Batch.find(id).update!(user: user) + user = User.find_by(login:) or raise StandardError, "Cannot find user login #{login.inspect}" + Batch.find(id).update!(user:) end When /^the batch is started$/ do diff --git a/features/support/step_definitions/bulk_submission_steps.rb b/features/support/step_definitions/bulk_submission_steps.rb index 83d6399dee..e8ad0987e4 100644 --- a/features/support/step_definitions/bulk_submission_steps.rb +++ b/features/support/step_definitions/bulk_submission_steps.rb @@ -21,12 +21,12 @@ def upload_custom_row_submission plate = FactoryBot.create :plate, name: asset_name plate.wells.construct! well = plate.wells.first - well.aliquots.create!(sample: sample) + well.aliquots.create!(sample:) end When /^the plate '(.*)' has a barcode '(.*)'$/ do |name, barcode| bc = SBCF::SangerBarcode.new(prefix: 'DN', number: barcode).human_barcode - Plate.find_by(name: name).primary_barcode.update(barcode: bc) + Plate.find_by(name:).primary_barcode.update(barcode: bc) end When /^the sample '(.*)' belongs to study '(.*)'$/ do |sample_name, study_name| diff --git a/features/support/step_definitions/custom_text_steps.rb b/features/support/step_definitions/custom_text_steps.rb index b036d036e5..efa0b8d1dd 100644 --- a/features/support/step_definitions/custom_text_steps.rb +++ b/features/support/step_definitions/custom_text_steps.rb @@ -9,7 +9,7 @@ end Given /^there is a CustomText with identifier: "([^"]*)", differential: "([^"]*)"$/ do |identifier, differential| - @current_custom_text = CustomText.find_by(identifier: identifier, differential: differential) + @current_custom_text = CustomText.find_by(identifier:, differential:) assert_not_nil @current_custom_text end diff --git a/features/support/step_definitions/debug_steps.rb b/features/support/step_definitions/debug_steps.rb index 8370928c08..d4d9015cff 100644 --- a/features/support/step_definitions/debug_steps.rb +++ b/features/support/step_definitions/debug_steps.rb @@ -1,7 +1,7 @@ # frozen_string_literal: true Then /^log "([^"]+)" for debugging$/ do |message| - Rails.logger.debug("#{('=' * 19)} #{message} #{('=' * 19)}") + Rails.logger.debug("#{'=' * 19} #{message} #{'=' * 19}") end Then /^launch the debugger$/ do diff --git a/features/support/step_definitions/display_submitted_at_inbox_pipeline_steps.rb b/features/support/step_definitions/display_submitted_at_inbox_pipeline_steps.rb index a6c3c0338d..1a0e999a2b 100644 --- a/features/support/step_definitions/display_submitted_at_inbox_pipeline_steps.rb +++ b/features/support/step_definitions/display_submitted_at_inbox_pipeline_steps.rb @@ -1,7 +1,7 @@ # frozen_string_literal: true Given(/^Pipeline "([^"]*)" and a setup for submitted at$/) do |name| - pipeline = Pipeline.find_by(name: name) or raise StandardError, "Cannot find pipeline '#{name}'" + pipeline = Pipeline.find_by(name:) or raise StandardError, "Cannot find pipeline '#{name}'" asset_type = pipeline_name_to_asset_type(name) request_type = pipeline.request_types.detect { |rt| !rt.deprecated } metadata = FactoryBot.create :"request_metadata_for_#{request_type.key}" diff --git a/features/support/step_definitions/genotyping_steps.rb b/features/support/step_definitions/genotyping_steps.rb index 2fa8b88349..aef87642e6 100644 --- a/features/support/step_definitions/genotyping_steps.rb +++ b/features/support/step_definitions/genotyping_steps.rb @@ -25,7 +25,7 @@ study = Study.find_by(name: study_name) purpose = Purpose.find_by(name: purpose_name) sanger_barcode = Barcode.build_sequencescape22({ barcode: plate_barcode }) - plate = FactoryBot.create(:plate, purpose: purpose, sanger_barcode: sanger_barcode) + plate = FactoryBot.create(:plate, purpose:, sanger_barcode:) asset_group = study.asset_groups.find_by(name: asset_group_name) || study.asset_groups.create!(name: asset_group_name) asset_group.assets << (1..number_of_samples.to_i).map do |index| diff --git a/features/support/step_definitions/order_steps.rb b/features/support/step_definitions/order_steps.rb index 517947112b..2c2edf30c5 100644 --- a/features/support/step_definitions/order_steps.rb +++ b/features/support/step_definitions/order_steps.rb @@ -5,8 +5,7 @@ end Given /^I have an order created with the following details based on the template "([^"]+)":$/ do |name, details| - template = SubmissionTemplate.find_by(name: name) or - raise StandardError, "Cannot find submission template #{name.inspect}" + template = SubmissionTemplate.find_by(name:) or raise StandardError, "Cannot find submission template #{name.inspect}" order_attributes = details.rows_hash.map do |k, v| v = @@ -25,15 +24,15 @@ [k.to_sym, v] end user = User.find_by(login: 'abc123') || FactoryBot.create(:user, login: 'abc123') - order = template.create_order!({ user: user }.merge(order_attributes.to_h)) + order = template.create_order!({ user: }.merge(order_attributes.to_h)) end Given /^an order template called "([^"]+)" with UUID "([^"]+)"$/ do |name, uuid_value| - set_uuid_for(FactoryBot.create(:submission_template, name: name), uuid_value) + set_uuid_for(FactoryBot.create(:submission_template, name:), uuid_value) end Given /^the UUID for the order template "([^"]+)" is "([^"]+)"$/ do |name, uuid_value| - object = SubmissionTemplate.find_by!(name: name) + object = SubmissionTemplate.find_by!(name:) set_uuid_for(object, uuid_value) end diff --git a/features/support/step_definitions/pipeline_steps.rb b/features/support/step_definitions/pipeline_steps.rb index 21ae5db7b2..f72785a6e3 100644 --- a/features/support/step_definitions/pipeline_steps.rb +++ b/features/support/step_definitions/pipeline_steps.rb @@ -53,7 +53,7 @@ def create_request_for_pipeline(pipeline_name, options = {}) # rubocop:todo Metr end Then /^the requests from "([^"]+)" batches should not be in the inbox$/ do |name| - pipeline = Pipeline.find_by(name: name) or raise StandardError, "Cannot find pipeline #{name.inspect}" + pipeline = Pipeline.find_by(name:) or raise StandardError, "Cannot find pipeline #{name.inspect}" raise StandardError, "There are no batches in #{name.inspect}" if pipeline.batches.empty? pipeline.batches.each do |batch| @@ -62,7 +62,7 @@ def create_request_for_pipeline(pipeline_name, options = {}) # rubocop:todo Metr end Given /^the maximum batch size for the pipeline "([^"]+)" is (\d+)$/ do |name, max_size| - pipeline = Pipeline.find_by(name: name) or raise StandardError, "Cannot find pipeline #{name.inspect}" + pipeline = Pipeline.find_by(name:) or raise StandardError, "Cannot find pipeline #{name.inspect}" pipeline.update!(max_size: max_size.to_i) end @@ -75,5 +75,5 @@ def create_request_for_pipeline(pipeline_name, options = {}) # rubocop:todo Metr end Given /^the last request is in the "([^"]+)" state$/ do |state| - Request.last.update!(state: state) + Request.last.update!(state:) end diff --git a/features/support/step_definitions/plate_steps.rb b/features/support/step_definitions/plate_steps.rb index 4ce301e7ea..0c2e4d3bac 100644 --- a/features/support/step_definitions/plate_steps.rb +++ b/features/support/step_definitions/plate_steps.rb @@ -27,11 +27,11 @@ Given /^plate with barcode "([^"]*)" has a well$/ do |plate_barcode| plate = Plate.find_from_barcode(plate_barcode) map = plate.maps.first - FactoryBot.create(:untagged_well, plate: plate, map: map) + FactoryBot.create(:untagged_well, plate:, map:) end Given 'a tube named {string} with barcode {string} exists' do |name, machine_barcode| - FactoryBot.create :tube, name: name, sanger_barcode: { machine_barcode: machine_barcode } + FactoryBot.create :tube, name: name, sanger_barcode: { machine_barcode: } end Given /^a plate with barcode "([^"]*)" exists$/ do |machine_barcode| @@ -58,7 +58,7 @@ end Given /^the plate with ID (\d+) has a plate purpose of "([^"]+)"$/ do |id, name| - purpose = PlatePurpose.find_by(name: name) or raise StandardError, "Cannot find plate purpose #{name.inspect}" + purpose = PlatePurpose.find_by(name:) or raise StandardError, "Cannot find plate purpose #{name.inspect}" Plate.find(id).update!(plate_purpose: purpose) end @@ -74,7 +74,7 @@ else FactoryBot.create( :plate, - sanger_barcode: Barcode.build_sanger_code39({ machine_barcode: machine_barcode }), + sanger_barcode: Barcode.build_sanger_code39({ machine_barcode: }), well_count: 8, plate_purpose: Purpose.find_by(name: plate_purpose_name) ) @@ -87,7 +87,7 @@ :plate, name: 'A_TEST_STOCK_PLATE', well_count: 8, - sanger_barcode: Barcode.build_sanger_code39({ machine_barcode: machine_barcode }), + sanger_barcode: Barcode.build_sanger_code39({ machine_barcode: }), plate_purpose: PlatePurpose.find_by(name: 'Stock Plate') ) end @@ -105,7 +105,7 @@ plate = Plate.find(plate_id) map = Map.where_description(position).where_plate_size(plate.size).where_plate_shape(plate.asset_shape).first or raise StandardError, "Could not find position #{position}" - Well.find(well_id).update!(plate: plate, map: map) + Well.find(well_id).update!(plate:, map:) end Given /^well "([^"]*)" is holded by plate "([^"]*)"$/ do |well_uuid, plate_uuid| @@ -120,7 +120,7 @@ end Given /^a "([^"]+)" plate called "([^"]+)" exists$/ do |name, plate_name| - plate_purpose = PlatePurpose.find_by!(name: name) + plate_purpose = PlatePurpose.find_by!(name:) plate_purpose.create!(name: plate_name) end @@ -144,13 +144,13 @@ end Given /^a "([^"]+)" plate called "([^"]+)" exists with barcode "([^"]+)"$/ do |name, plate_name, barcode| - plate_purpose = PlatePurpose.find_by!(name: name) + plate_purpose = PlatePurpose.find_by!(name:) step("the Baracoda barcode service returns \"#{barcode}\"") plate_purpose.create!(name: plate_name, barcode: barcode) end Given /^a "([^"]+)" plate called "([^"]+)" exists as a child of "([^"]+)"$/ do |name, plate_name, parent_name| - plate_purpose = PlatePurpose.find_by(name: name) or raise StandardError, "Cannot find plate purpose #{name.inspect}" + plate_purpose = PlatePurpose.find_by(name:) or raise StandardError, "Cannot find plate purpose #{name.inspect}" parent = Plate.find_by(name: parent_name) or raise StandardError, "Cannot find parent plate #{parent_name.inspect}" AssetLink.create!(ancestor: parent, descendant: plate_purpose.create!(name: plate_name)) end diff --git a/features/support/step_definitions/project_steps.rb b/features/support/step_definitions/project_steps.rb index 32cef3cfd2..d58d71c417 100644 --- a/features/support/step_definitions/project_steps.rb +++ b/features/support/step_definitions/project_steps.rb @@ -17,7 +17,7 @@ end Given /^project "([^"]*)" has enforced quotas$/ do |name| - project = Project.find_by(name: name) or raise StandardError, "Cannot find project with name #{name.inspect}" + project = Project.find_by(name:) or raise StandardError, "Cannot find project with name #{name.inspect}" project.update!(enforce_quotas: true) end @@ -32,5 +32,5 @@ budget_division = BudgetDivision.find_by(name: budget_division_name) or raise StandardError, "Cannot find budget division #{budget_division_name.inspect}" - project.update!(project_metadata_attributes: { budget_division: budget_division }) + project.update!(project_metadata_attributes: { budget_division: }) end diff --git a/features/support/step_definitions/pulldown_steps.rb b/features/support/step_definitions/pulldown_steps.rb index 8c2e4f2ffb..9a653275a1 100644 --- a/features/support/step_definitions/pulldown_steps.rb +++ b/features/support/step_definitions/pulldown_steps.rb @@ -77,7 +77,7 @@ def create_submission_of_assets(template, assets, request_options = {}) def work_pipeline_for(submissions, name, template = nil) # rubocop:todo Metrics/CyclomaticComplexity raise StandardError, 'No submissions to process' if submissions.empty? - final_plate_type = PlatePurpose.find_by(name: name) or raise StandardError, "Cannot find #{name.inspect} plate type" + final_plate_type = PlatePurpose.find_by(name:) or raise StandardError, "Cannot find #{name.inspect} plate type" template ||= TransferTemplate.find_by(name: 'Pool wells based on submission') or raise StandardError, 'Cannot find pooling transfer template' @@ -123,7 +123,7 @@ def work_pipeline_for(submissions, name, template = nil) # rubocop:todo Metrics/ end Then /^all "([^"]+)" requests should have the following details:$/ do |name, table| - request_type = RequestType.find_by(name: name) or raise StandardError, "Could not find request type #{name.inspect}" + request_type = RequestType.find_by(name:) or raise StandardError, "Could not find request type #{name.inspect}" raise StandardError, "No requests of type #{name.inspect}" if request_type.requests.empty? results = @@ -156,7 +156,7 @@ def work_pipeline_for(submissions, name, template = nil) # rubocop:todo Metrics/ Given '{plate_name} will pool into 1 tube' do |plate| well_count = plate.wells.count - stock_plate = FactoryBot.create :full_stock_plate, well_count: well_count + stock_plate = FactoryBot.create(:full_stock_plate, well_count:) stock_wells = stock_plate.wells submission = Submission.create!(user: FactoryBot.create(:user)) diff --git a/features/support/step_definitions/reference_genome_steps.rb b/features/support/step_definitions/reference_genome_steps.rb index ac9d4d1d39..da24713ed2 100644 --- a/features/support/step_definitions/reference_genome_steps.rb +++ b/features/support/step_definitions/reference_genome_steps.rb @@ -1,7 +1,7 @@ # frozen_string_literal: true Given /^the reference genome "([^"]*)" exists$/ do |name| - FactoryBot.create :reference_genome, name: name + FactoryBot.create :reference_genome, name: end Given /^a reference genome table$/ do diff --git a/features/support/step_definitions/request_steps.rb b/features/support/step_definitions/request_steps.rb index 9b6ae066ab..88c65dd469 100644 --- a/features/support/step_definitions/request_steps.rb +++ b/features/support/step_definitions/request_steps.rb @@ -2,7 +2,7 @@ Given /^user "([^"]*)" owns all requests$/ do |user_name| user = FactoryBot.create :user, login: user_name - Request.find_each { |request| request.update!(user: user) } + Request.find_each { |request| request.update!(user:) } end Given /^all requests have a priority flag$/ do diff --git a/features/support/step_definitions/robot_verification_steps.rb b/features/support/step_definitions/robot_verification_steps.rb index 4956369bdb..c974a84895 100644 --- a/features/support/step_definitions/robot_verification_steps.rb +++ b/features/support/step_definitions/robot_verification_steps.rb @@ -90,7 +90,7 @@ end Given /^user "([^"]*)" has a user barcode of "([^"]*)"$/ do |login, user_barcode| - user = User.find_by(login: login) + user = User.find_by(login:) user.update!(barcode: user_barcode) end diff --git a/features/support/step_definitions/role_steps.rb b/features/support/step_definitions/role_steps.rb index cd667c2d99..c6d7d4c049 100644 --- a/features/support/step_definitions/role_steps.rb +++ b/features/support/step_definitions/role_steps.rb @@ -13,6 +13,6 @@ end Given /^user "([^"]+)" is an administrator$/ do |login| - user = User.find_by(login: login) or raise StandardError, "Cannot find user with login #{login.inspect}" + user = User.find_by(login:) or raise StandardError, "Cannot find user with login #{login.inspect}" user.roles.create!(name: 'administrator') end diff --git a/features/support/step_definitions/sample_manifest_steps.rb b/features/support/step_definitions/sample_manifest_steps.rb index bb9e80dd17..65a265df41 100644 --- a/features/support/step_definitions/sample_manifest_steps.rb +++ b/features/support/step_definitions/sample_manifest_steps.rb @@ -5,7 +5,7 @@ end Given /^the library type "([^"]+)" exists$/ do |name| - LibraryType.find_or_create_by(name: name) + LibraryType.find_or_create_by(name:) end Given /^the study "(.*)" has a abbreviation$/ do |study_name| @@ -71,7 +71,7 @@ def instance.next! Then /^the samples table should look like:$/ do |table| table.hashes.each do |expected_data| sanger_sample_id = expected_data[:sanger_sample_id] - sample = Sample.find_by(sanger_sample_id: sanger_sample_id) + sample = Sample.find_by(sanger_sample_id:) if expected_data.fetch(:empty_supplier_sample_name, expected_data[:sample_absent]) == 'true' assert_nil sample, "#{sanger_sample_id} exists but should not be created" @@ -113,7 +113,7 @@ def instance.next! Then /^the sample accession numbers should be:$/ do |table| table.hashes.each do |expected_data| sanger_sample_id = expected_data[:sanger_sample_id] - sample = Sample.find_by!(sanger_sample_id: sanger_sample_id) + sample = Sample.find_by!(sanger_sample_id:) assert_equal(expected_data[:accession_number], sample.sample_metadata.sample_ebi_accession_number) end end @@ -121,8 +121,7 @@ def instance.next! Then /^the sample reference genomes should be:$/ do |table| table.hashes.each do |expected_data| sanger_sample_id = expected_data[:sanger_sample_id] - sample = Sample.find_by(sanger_sample_id: sanger_sample_id) or - raise StandardError, "Could not find sample #{sanger_sample_id}" + sample = Sample.find_by(sanger_sample_id:) or raise StandardError, "Could not find sample #{sanger_sample_id}" assert_equal(expected_data[:reference_genome], sample.sample_metadata.reference_genome.name) end end @@ -223,14 +222,14 @@ def instance.next! When /^the sample manifest with ID (\d+) is owned by study "([^"]+)"$/ do |id, name| manifest = SampleManifest.find(id) - study = Study.find_by(name: name) or raise StandardError, "Cannot find study #{name.inspect}" - manifest.update!(study: study) + study = Study.find_by(name:) or raise StandardError, "Cannot find study #{name.inspect}" + manifest.update!(study:) end When /^the sample manifest with ID (\d+) is supplied by "([^"]+)"$/ do |id, name| manifest = SampleManifest.find(id) - supplier = Supplier.find_by(name: name) or raise StandardError, "Cannot find supplier #{name.inspect}" - manifest.update!(supplier: supplier) + supplier = Supplier.find_by(name:) or raise StandardError, "Cannot find supplier #{name.inspect}" + manifest.update!(supplier:) end Given /^the sample manifest with ID (\d+) is for (\d+) sample tube$/ do |id, count| diff --git a/features/support/step_definitions/sample_metadata_steps.rb b/features/support/step_definitions/sample_metadata_steps.rb index bb9821f41d..fe8dec4b3f 100644 --- a/features/support/step_definitions/sample_metadata_steps.rb +++ b/features/support/step_definitions/sample_metadata_steps.rb @@ -1,6 +1,6 @@ # frozen_string_literal: true Given /^the fields of the sample_metadata for the sample called "([^"]+)" are prepopulated$/ do |name| - sample = Sample.find_by!(name: name) + sample = Sample.find_by!(name:) sample.update!(sample_metadata_attributes: FactoryBot.attributes_for(:sample_metadata_for_api)) end diff --git a/features/support/step_definitions/samples_steps.rb b/features/support/step_definitions/samples_steps.rb index 519e1e715d..e0918df5ce 100644 --- a/features/support/step_definitions/samples_steps.rb +++ b/features/support/step_definitions/samples_steps.rb @@ -1,37 +1,37 @@ # frozen_string_literal: true Given /^the sample "([^"]+)" has the Taxon ID "([^"]+)"$/ do |name, id| - sample = Sample.find_by(name: name) or raise StandardError, "Cannot find sample with name #{name.inspect}" + sample = Sample.find_by(name:) or raise StandardError, "Cannot find sample with name #{name.inspect}" sample.sample_metadata.sample_taxon_id = id sample.save! end Given /^the sample "([^"]+)" has the common name "([^"]*)"$/ do |name, common_name| - sample = Sample.find_by(name: name) or raise StandardError, "Cannot find sample with name #{name.inspect}" + sample = Sample.find_by(name:) or raise StandardError, "Cannot find sample with name #{name.inspect}" sample.sample_metadata.sample_common_name = common_name sample.save! end Given /^the sample "([^"]+)" has the gender "([^"]*)"$/ do |name, gender| - sample = Sample.find_by(name: name) or raise StandardError, "Cannot find sample with name #{name.inspect}" + sample = Sample.find_by(name:) or raise StandardError, "Cannot find sample with name #{name.inspect}" sample.sample_metadata.gender = gender sample.save! end Given /^the sample "([^"]+)" has the donor id "([^"]*)"$/ do |name, donor_id| - sample = Sample.find_by(name: name) or raise StandardError, "Cannot find sample with name #{name.inspect}" + sample = Sample.find_by(name:) or raise StandardError, "Cannot find sample with name #{name.inspect}" sample.sample_metadata.donor_id = donor_id sample.save! end Given /^the sample "([^"]+)" has the phenotype "([^"]*)"$/ do |name, phenotype| - sample = Sample.find_by(name: name) or raise StandardError, "Cannot find sample with name #{name.inspect}" + sample = Sample.find_by(name:) or raise StandardError, "Cannot find sample with name #{name.inspect}" sample.sample_metadata.phenotype = phenotype sample.save! end Given /^the reference genome for sample "([^"]+)" is "([^"]+)"$/ do |name, value| - sample = Sample.find_by!(name: name) + sample = Sample.find_by!(name:) ref_genome = ReferenceGenome.find_or_create_by!(name: value) sample.sample_metadata.reference_genome = ref_genome sample.save! @@ -45,7 +45,7 @@ end Then /^the reference genome for the sample "([^"]+)" should be "([^"]+)"$/ do |name, genome| - sample = Sample.find_by(name: name) or raise StandardError, "Cannot find sample with name #{name.inspect}" + sample = Sample.find_by(name:) or raise StandardError, "Cannot find sample with name #{name.inspect}" assert_equal(genome, sample.sample_metadata.reference_genome.name) end @@ -100,26 +100,26 @@ end Then /^the sample "([^"]+)" should exist$/ do |name| - assert_not_nil(Sample.find_by(name: name), "The sample #{name.inspect} does not exist") + assert_not_nil(Sample.find_by(name:), "The sample #{name.inspect} does not exist") end Then /^the sample "([^"]+)" should have an associated sample tube$/ do |name| - sample = Sample.find_by(name: name) or raise StandardError, "Cannot find sample with name #{name.inspect}" + sample = Sample.find_by(name:) or raise StandardError, "Cannot find sample with name #{name.inspect}" assert(!sample.assets.empty?, 'No associated sample tubes') end When /^I get the XML for the sample "([^"]+)"$/ do |name| - sample = Sample.find_by(name: name) or raise StandardError, "Cannot find sample with name #{name.inspect}" + sample = Sample.find_by(name:) or raise StandardError, "Cannot find sample with name #{name.inspect}" visit(url_for(controller: 'samples', action: 'show', id: sample, format: :xml)) end Given /^I have a sample called "([^"]*)" with metadata$/ do |name| - sample = FactoryBot.create :sample, name: name + sample = FactoryBot.create :sample, name: end Given /^the sample "([^"]*)" has a supplier name of "([^"]*)"$/ do |sample_name, supplier_name| sample = Sample.find_by(name: sample_name) - sample.sample_metadata.update!(supplier_name: supplier_name) + sample.sample_metadata.update!(supplier_name:) end Given /^the sample "([^"]+)" is in the (sample tube|well) "([^"]+)"$/ do |sample_name, _asset_type, asset_name| @@ -127,11 +127,11 @@ asset = Labware.find_by(name: asset_name).receptacle or raise StandardError, "Cannot find sample tube #{asset_name.inspect}" asset.aliquots.clear - asset.aliquots.create!(sample: sample) + asset.aliquots.create!(sample:) end Given(/^the sample "([^"]+)" has the accession number "([^"]+)"$/) do |name, value| - sample = Sample.find_by!(name: name) + sample = Sample.find_by!(name:) sample.sample_metadata.sample_ebi_accession_number = value.presence sample.save! end @@ -159,7 +159,7 @@ Given /^sample "([^"]*)" came from a sample manifest$/ do |sample_name| sample = Sample.find_by(name: sample_name) sample_manifest = FactoryBot.create(:sample_manifest, id: 1) - sample.update!(sample_manifest: sample_manifest) + sample.update!(sample_manifest:) end Given /^a sample named "([^"]+)" exists for accession/ do |sample_name| @@ -188,37 +188,37 @@ end Given /^the sample called "([^"]+)" is (#{Sample::GENDERS.join('|')})$/ do |name, gender| - sample = Sample.find_by(name: name) or raise StandardError, "Cannot find the sample #{name.inspect}" - sample.update!(sample_metadata_attributes: { gender: gender }) + sample = Sample.find_by(name:) or raise StandardError, "Cannot find the sample #{name.inspect}" + sample.update!(sample_metadata_attributes: { gender: }) end Given /^the GC content of the sample called "([^"]+)" is (#{Sample::GC_CONTENTS.join('|')})$/ do |name, gc_content| - sample = Sample.find_by(name: name) or raise StandardError, "Cannot find the sample #{name.inspect}" - sample.update!(sample_metadata_attributes: { gc_content: gc_content }) + sample = Sample.find_by(name:) or raise StandardError, "Cannot find the sample #{name.inspect}" + sample.update!(sample_metadata_attributes: { gc_content: }) end Given /^the DNA source of the sample called "([^"]+)" is (#{Sample::DNA_SOURCES.join('|')})$/ do |name, source| - sample = Sample.find_by(name: name) or raise StandardError, "Cannot find the sample #{name.inspect}" + sample = Sample.find_by(name:) or raise StandardError, "Cannot find the sample #{name.inspect}" sample.update!(sample_metadata_attributes: { dna_source: source }) end Given /^the SRA status of the sample called "([^"]+)" is (#{Sample::SRA_HOLD_VALUES.join('|')})$/ do |name, sra_status| - sample = Sample.find_by(name: name) or raise StandardError, "Cannot find the sample #{name.inspect}" + sample = Sample.find_by(name:) or raise StandardError, "Cannot find the sample #{name.inspect}" sample.update!(sample_metadata_attributes: { sample_sra_hold: sra_status }) end Given /^the sample called "([^"]+)" is (#{Sample::AGE_REGEXP}) old$/o do |name, age| - sample = Sample.find_by(name: name) or raise StandardError, "Cannot find the sample #{name.inspect}" - sample.update!(sample_metadata_attributes: { age: age }) + sample = Sample.find_by(name:) or raise StandardError, "Cannot find the sample #{name.inspect}" + sample.update!(sample_metadata_attributes: { age: }) end Given /^the dosage of the sample called "([^"]+)" is (#{Sample::DOSE_REGEXP})/o do |name, dose| - sample = Sample.find_by(name: name) or raise StandardError, "Cannot find the sample #{name.inspect}" - sample.update!(sample_metadata_attributes: { dose: dose }) + sample = Sample.find_by(name:) or raise StandardError, "Cannot find the sample #{name.inspect}" + sample.update!(sample_metadata_attributes: { dose: }) end Given /^the description of the sample called "([^"]+)" contains quotes/ do |name| - sample = Sample.find_by(name: name) or raise StandardError, "Cannot find the sample #{name.inspect}" + sample = Sample.find_by(name:) or raise StandardError, "Cannot find the sample #{name.inspect}" sample.update!(sample_metadata_attributes: { sample_description: 'something "with" quotes' }) end diff --git a/features/support/step_definitions/study_steps.rb b/features/support/step_definitions/study_steps.rb index a6aea75424..e3bacbb72b 100644 --- a/features/support/step_definitions/study_steps.rb +++ b/features/support/step_definitions/study_steps.rb @@ -43,7 +43,7 @@ created_at: Time.zone.now, updated_at: Time.zone.now end - usr = User.find_by(login: login) + usr = User.find_by(login:) usr.roles << role usr.save end @@ -64,7 +64,7 @@ def given_fixed_study_metadata(attribute, value, regexp) Given(regexp) do |name| - study = Study.find_by(name: name) or raise StandardError, "There appears to be no study named '#{name}'" + study = Study.find_by(name:) or raise StandardError, "There appears to be no study named '#{name}'" study.study_metadata.send(:"#{attribute}=", value) study.save! end @@ -94,7 +94,7 @@ def given_fixed_study_metadata(attribute, value, regexp) def given_study_metadata(attribute, regexp) Given(regexp) do |name, value| - study = Study.find_by(name: name) or raise StandardError, "There appears to be no study named '#{name}'" + study = Study.find_by(name:) or raise StandardError, "There appears to be no study named '#{name}'" study.study_metadata.send(:"#{attribute}=", value.presence) study.save! end @@ -112,28 +112,28 @@ def given_study_metadata(attribute, regexp) end Given(/^the study "([^"]+)" is a "([^"]*)" study$/) do |name, value| - study = Study.find_by!(name: name) + study = Study.find_by!(name:) study_type = StudyType.find_by!(name: value) study.study_metadata.study_type = study_type study.save! end Given(/^the study "([^"]+)" is a "([^"]+)" study for data release$/) do |name, value| - study = Study.find_by!(name: name) + study = Study.find_by!(name:) study_type_dr = DataReleaseStudyType.find_by!(name: value) study.study_metadata.data_release_study_type = study_type_dr study.save! end Given(/^the faculty sponsor for study "([^"]+)" is "([^"]+)"$/) do |name, value| - study = Study.find_by!(name: name) + study = Study.find_by!(name:) faculty_sponsor = FacultySponsor.create!(name: value) study.study_metadata.faculty_sponsor = faculty_sponsor study.save! end Given(/^the reference genome for study "([^"]+)" is "([^"]+)"$/) do |name, value| - study = Study.find_by!(name: name) + study = Study.find_by!(name:) ref_genome = ReferenceGenome.find_or_create_by!(name: value) study.study_metadata.reference_genome = ref_genome study.save! @@ -148,14 +148,14 @@ def given_study_metadata(attribute, regexp) given_study_metadata(:ega_policy_accession_number, /^the EGA policy accession number for study "([^"]+)" is "([^"]+)"$/) Given /^the (abstract|description|title) of study "([^"]+)" is "([^"]*)"$/ do |attribute, name, description| - study = Study.find_by(name: name) or raise StandardError, "There appears to be no study named '#{name}'" + study = Study.find_by(name:) or raise StandardError, "There appears to be no study named '#{name}'" attribute = 'study_title' if attribute == 'title' # Got to love consistency study.study_metadata.send(:"study_#{attribute}=", description) study.save! end Given /^the study "([^"]+)" is delayed for (3|6|9|12) months because "([^"]+)"$/ do |name, period, reason| - study = Study.find_by(name: name) or raise StandardError, "There appears to be no study named '#{name}'" + study = Study.find_by(name:) or raise StandardError, "There appears to be no study named '#{name}'" study.update!( study_metadata_attributes: { data_release_timing: 'delayed', @@ -182,7 +182,7 @@ def given_study_metadata(attribute, regexp) end Given /^study "([^"]*)" has an accession number$/ do |name| - study = Study.find_by(name: name) or raise StandardError, "Cannot find study with name '#{name}'" + study = Study.find_by(name:) or raise StandardError, "Cannot find study with name '#{name}'" study.study_metadata.study_ebi_accession_number = 9999 study.study_metadata.data_release_strategy ||= 'managed' study.save! @@ -228,7 +228,7 @@ def assign_asset_to_study(asset, study_name) assert_not_nil study.abbreviation.match(Regexp.new(abbreviation_regex)) end When /^I get the XML accession for the study *"([^"]+)"$/ do |name| - study = Study.find_by(name: name) or raise StandardError, "Cannot find sample with name #{name.inspect}" + study = Study.find_by(name:) or raise StandardError, "Cannot find sample with name #{name.inspect}" visit(url_for(controller: 'studies', action: 'show_accession', id: study.id, format: :xml)) end diff --git a/features/support/step_definitions/submission_steps.rb b/features/support/step_definitions/submission_steps.rb index 861170bc82..77ea087ab6 100644 --- a/features/support/step_definitions/submission_steps.rb +++ b/features/support/step_definitions/submission_steps.rb @@ -9,7 +9,7 @@ When /^the state of the submission with UUID "([^"]+)" is "([^"]+)"$/ do |uuid, state| submission = Uuid.with_external_id(uuid).first.try(:resource) or raise StandardError, "Could not find submission with UUID #{uuid.inspect}" - submission.update!(state: state) + submission.update!(state:) end Then /^there should be no submissions to be processed$/ do @@ -88,15 +88,13 @@ end Given /^the request type "([^"]+)" exists$/ do |name| - FactoryBot.create(:request_type, name: name) + FactoryBot.create(:request_type, name:) end def submission_in_state(state, attributes = {}) study = Study.first or raise StandardError, 'There are no studies!' submission = - FactoryHelp.submission( - { asset_group_name: 'Faked to prevent empty asset errors' }.merge(attributes).merge(study: study) - ) + FactoryHelp.submission({ asset_group_name: 'Faked to prevent empty asset errors' }.merge(attributes).merge(study:)) submission.state = state submission.save(validate: false) end @@ -106,7 +104,7 @@ def submission_in_state(state, attributes = {}) end Given /^I have a submission in the "failed" state with message "([^"]+)"$/ do |message| - submission_in_state('failed', message: message) + submission_in_state('failed', message:) end # These are the sensible default values for requests, which later get bound to the request types @@ -139,9 +137,9 @@ def submission_in_state(state, attributes = {}) 'Illumina-B HiSeq Paired end sequencing' => SENSIBLE_DEFAULTS_HISEQ }.freeze -def with_request_type_scope(name, &block) - request_type = RequestType.find_by(name: name) or raise StandardError, "Cannot find request type #{name.inspect}" - with_scope("#request_type_options_for_#{request_type.id}", &block) +def with_request_type_scope(name, &) + request_type = RequestType.find_by(name:) or raise StandardError, "Cannot find request type #{name.inspect}" + with_scope("#request_type_options_for_#{request_type.id}", &) end When /^I fill in "([^"]+)" with "([^"]+)" for the "([^"]+)" request type$/ do |name, value, type| @@ -185,7 +183,7 @@ def with_request_type_scope(name, &block) # step(%Q{1 pending delayed jobs are processed}) end Then /^the last submission should have a priority of (\d+)$/ do |priority| - Submission.last.update!(priority: priority) + Submission.last.update!(priority:) end Given /^all the requests in the last submission are cancelled$/ do diff --git a/features/support/step_definitions/tag_layout_steps.rb b/features/support/step_definitions/tag_layout_steps.rb index b2c4798335..8a829ebedc 100644 --- a/features/support/step_definitions/tag_layout_steps.rb +++ b/features/support/step_definitions/tag_layout_steps.rb @@ -1,7 +1,7 @@ # frozen_string_literal: true Given /^the ((?:entire plate |inverted )?tag layout template) "([^"]+)" exists$/ do |style, name| - FactoryBot.create(style.tr(' ', '_'), name: name) + FactoryBot.create(style.tr(' ', '_'), name:) end Given /^the tag 2 layout template "([^"]+)" exists$/ do |name| @@ -53,7 +53,7 @@ def plate_view_of_oligos(label, mapping) # rubocop:todo Metrics/AbcSize end def check_tag_layout(name, well_range, expected_wells_to_oligos) # rubocop:todo Metrics/MethodLength - plate = Plate.find_by(name: name) or raise StandardError, "Cannot find plate #{name.inspect}" + plate = Plate.find_by(name:) or raise StandardError, "Cannot find plate #{name.inspect}" wells_to_oligos = plate .wells @@ -70,7 +70,7 @@ def check_tag_layout(name, well_range, expected_wells_to_oligos) # rubocop:todo end end def check_tag2_layout(name, well_range, expected_wells_to_oligos) # rubocop:todo Metrics/MethodLength - plate = Plate.find_by(name: name) or raise StandardError, "Cannot find plate #{name.inspect}" + plate = Plate.find_by(name:) or raise StandardError, "Cannot find plate #{name.inspect}" wells_to_oligos = plate .wells @@ -149,7 +149,7 @@ def pool_by_strategy(source, destination, pooling_strategy) # rubocop:todo Metri end Given /^the tag group "(.*?)" exists$/ do |name| - TagGroup.create!(name: name) + TagGroup.create!(name:) end Given /^the tag group "(.*?)" has (\d+) tags$/ do |group, count| diff --git a/features/support/step_definitions/transfer_steps.rb b/features/support/step_definitions/transfer_steps.rb index 28d588c6a8..8f70e44691 100644 --- a/features/support/step_definitions/transfer_steps.rb +++ b/features/support/step_definitions/transfer_steps.rb @@ -13,7 +13,7 @@ def transfer_model(name) end Given /^the transfer (between plates|from plate to tube) exists with ID (\d+)$/ do |name, id| - FactoryBot.create(:"transfer_#{name.gsub(/\s+/, '_')}", id: id) + FactoryBot.create(:"transfer_#{name.gsub(/\s+/, '_')}", id:) end # rubocop:todo Layout/LineLength @@ -23,7 +23,7 @@ def transfer_model(name) end Given /^the ((?:pooling ||multiplex )?transfer template) called "([^"]+)" exists$/ do |type, name| - FactoryBot.create(type.gsub(/\s/, '_').to_sym, name: name) + FactoryBot.create(type.gsub(/\s/, '_').to_sym, name:) end Then 'the transfers from {plate_name} to {plate_name} should be:' do |source, destination, table| @@ -42,16 +42,16 @@ def transfer_model(name) end Given /^a transfer plate exists with ID (\d+)$/ do |id| - FactoryBot.create(:transfer_plate, id: id) + FactoryBot.create(:transfer_plate, id:) end Given /^a transfer plate called "([^"]+)" exists$/ do |name| - FactoryBot.create(:transfer_plate, name: name) + FactoryBot.create(:transfer_plate, name:) end Given /^the plate "(.*?)" has additional wells$/ do |name| Plate - .find_by(name: name) + .find_by(name:) .tap do |plate| plate.wells << %w[C1 D1].map do |location| map = @@ -60,19 +60,19 @@ def transfer_model(name) .where_plate_size(plate.size) .where_plate_shape(AssetShape.find_by(name: 'Standard')) .first or raise StandardError, "No location #{location} on plate #{plate.inspect}" - FactoryBot.create(:tagged_well, map: map) + FactoryBot.create(:tagged_well, map:) end end end Given /^a transfer plate called "([^"]+)" exists as a child of "([^"]+)"$/ do |name, parent| parent_plate = Plate.find_by!(name: parent) - AssetLink.create!(ancestor: parent_plate, descendant: FactoryBot.create(:transfer_plate, name: name)) + AssetLink.create!(ancestor: parent_plate, descendant: FactoryBot.create(:transfer_plate, name:)) end Given(/^a transfer plate called "([^"]*)" exists as a child of plate (\d+)$/) do |name, parent_id| parent_plate = Plate.find(parent_id) - AssetLink.create!(ancestor: parent_plate, descendant: FactoryBot.create(:transfer_plate, name: name)) + AssetLink.create!(ancestor: parent_plate, descendant: FactoryBot.create(:transfer_plate, name:)) end # rubocop:todo Layout/LineLength @@ -99,7 +99,7 @@ def change_request_state(state, targets, direction, request_class) association = direction == 'to' ? :requests_as_target : :requests_as_source Request.where( id: Array(targets).map(&association).flatten.select { |r| r.is_a?(request_class) }.map(&:id) - ).update_all(state: state) + ).update_all(state:) end # rubocop:todo Layout/LineLength @@ -162,6 +162,6 @@ def change_request_state(state, targets, direction, request_class) plate.wells.includes(:aliquots).find_each { |w| w.aliquots.each { |a| assert_equal study.id, a.study_id } } end Given '{asset_name} is a {string}' do |plate, name| - plate_purpose = Purpose.find_by!(name: name) - plate.update!(plate_purpose: plate_purpose) + plate_purpose = Purpose.find_by!(name:) + plate.update!(plate_purpose:) end diff --git a/features/support/step_definitions/user_steps.rb b/features/support/step_definitions/user_steps.rb index 108e3c275b..d394c2ece0 100644 --- a/features/support/step_definitions/user_steps.rb +++ b/features/support/step_definitions/user_steps.rb @@ -5,7 +5,7 @@ end Given /^a user with an api key of "([^"]*)" exists$/ do |api_key| - @current_user = FactoryBot.create :user, api_key: api_key + @current_user = FactoryBot.create :user, api_key: end Given /^I have an active project called "([^"]*)"$/ do |project_name| @@ -24,14 +24,14 @@ Given /^user "([^"]*)" exists with barcode "([^"]*)"$/ do |user_name, barcode| if User.find_by(login: user_name) - User.find_by(login: user_name).update!(barcode: barcode) + User.find_by(login: user_name).update!(barcode:) else FactoryBot.create :user, barcode: barcode, login: user_name end end Given /^the user with login "([^"]+)" exists$/ do |login| - User.find_by(login: login) || FactoryBot.create(:user, login: login) + User.find_by(login:) || FactoryBot.create(:user, login:) end Then /^the user (\d+) should validate the swipecard code "([^"]+)"/ do |user_id, code| diff --git a/features/support/step_definitions/uuid_steps.rb b/features/support/step_definitions/uuid_steps.rb index 69d0136545..0c5922b675 100644 --- a/features/support/step_definitions/uuid_steps.rb +++ b/features/support/step_definitions/uuid_steps.rb @@ -57,8 +57,7 @@ def set_uuid_for(object, uuid_value) # rubocop:todo Layout/LineLength Given /^the UUID for the (#{SINGULAR_MODELS_BASED_ON_NAME_REGEXP}) "([^"]+)" is "([^"]+)"$/o do |model, name, uuid_value| # rubocop:enable Layout/LineLength - object = model.gsub(/\s+/, '_').classify.constantize.find_by(name: name) or - raise "Cannot find #{model} #{name.inspect}" + object = model.gsub(/\s+/, '_').classify.constantize.find_by(name:) or raise "Cannot find #{model} #{name.inspect}" set_uuid_for(object, uuid_value) end @@ -67,23 +66,22 @@ def set_uuid_for(object, uuid_value) # rubocop:todo Layout/LineLength Given /^the UUID for the receptacle in (#{SINGULAR_MODELS_BASED_ON_NAME_REGEXP}) "([^"]+)" is "([^"]+)"$/o do |model, name, uuid_value| # rubocop:enable Layout/LineLength - object = model.gsub(/\s+/, '_').classify.constantize.find_by(name: name) or - raise "Cannot find #{model} #{name.inspect}" + object = model.gsub(/\s+/, '_').classify.constantize.find_by(name:) or raise "Cannot find #{model} #{name.inspect}" set_uuid_for(object.receptacle, uuid_value) end # rubocop:todo Layout/LineLength Given /^an? (#{SINGULAR_MODELS_BASED_ON_NAME_REGEXP}) called "([^"]+)" with UUID "([^"]+)"$/o do |model, name, uuid_value| # rubocop:enable Layout/LineLength - set_uuid_for(FactoryBot.create(model.gsub(/\s+/, '_').to_sym, name: name), uuid_value) + set_uuid_for(FactoryBot.create(model.gsub(/\s+/, '_').to_sym, name:), uuid_value) end Given /^a tube purpose called "([^"]+)" with UUID "([^"]+)"$/ do |name, uuid_value| - set_uuid_for(FactoryBot.create(:tube_purpose, name: name), uuid_value) + set_uuid_for(FactoryBot.create(:tube_purpose, name:), uuid_value) end Given /^an? (#{SINGULAR_MODELS_BASED_ON_NAME_REGEXP}) called "([^"]+)" with ID (\d+)$/o do |model, name, id| - FactoryBot.create(model.gsub(/\s+/, '_').to_sym, name: name, id: id) + FactoryBot.create(model.gsub(/\s+/, '_').to_sym, name:, id:) end # rubocop:todo Layout/LineLength @@ -225,7 +223,7 @@ def set_uuid_for(object, uuid_value) end Given /^the (#{SINGULAR_MODELS_BASED_ON_ID_REGEXP}) exists with ID (\d+)$/o do |model, id| - FactoryBot.create(model.gsub(/\s+/, '_').to_sym, id: id) + FactoryBot.create(model.gsub(/\s+/, '_').to_sym, id:) end # rubocop:todo Layout/LineLength diff --git a/features/support/step_definitions/various_object_construction_steps.rb b/features/support/step_definitions/various_object_construction_steps.rb index 47788fb49d..c926830224 100644 --- a/features/support/step_definitions/various_object_construction_steps.rb +++ b/features/support/step_definitions/various_object_construction_steps.rb @@ -3,9 +3,9 @@ # rubocop:todo Layout/LineLength Given /^(?:a|the) (project|study|sample|sample tube|library tube|plate|pulldown multiplexed library tube|multiplexed library tube|faculty sponsor) (?:named|called) "([^"]+)" exists$/ do |type, name| # rubocop:enable Layout/LineLength - FactoryBot.create(type.gsub(/[^a-z0-9]+/, '_').to_sym, name: name) + FactoryBot.create(type.gsub(/[^a-z0-9]+/, '_').to_sym, name:) end Given /^(?:a|the) lane (?:named|called) "([^"]+)" exists$/ do |name| - FactoryBot.create(:lane, name: name) + FactoryBot.create(:lane, name:) end diff --git a/features/support/step_definitions/web_form_steps.rb b/features/support/step_definitions/web_form_steps.rb index 512f7557ed..a4ae33933d 100644 --- a/features/support/step_definitions/web_form_steps.rb +++ b/features/support/step_definitions/web_form_steps.rb @@ -72,7 +72,7 @@ def locate_labeled_field_type(label_text, field_type) # rubocop:todo Metrics/Cyc end # rubocop:todo Layout/LineLength -Then %r{^I should see the (required )?select field "([^"]+)" with options "([^"]+(?:\/[^"]+)+)"$} do |required, field, options| +Then %r{^I should see the (required )?select field "([^"]+)" with options "([^"]+(?:/[^"]+)+)"$} do |required, field, options| # rubocop:enable Layout/LineLength assert_label_exists(field, required) element = locate_labeled_field_type(field, 'select') diff --git a/features/support/step_definitions/web_steps.rb b/features/support/step_definitions/web_steps.rb index e71501cd4a..55f99dc732 100644 --- a/features/support/step_definitions/web_steps.rb +++ b/features/support/step_definitions/web_steps.rb @@ -75,7 +75,7 @@ def with_scope(locator) When /^(?:|I )check (the invisible )?"([^"]*)"(?: within "([^"]*)")?$/ do |invisible, field, selector| visible = invisible != 'the invisible ' - with_scope(selector) { check(field, visible: visible) } + with_scope(selector) { check(field, visible:) } end When /^(?:|I )uncheck "([^"]*)"(?: within "([^"]*)")?$/ do |field, selector| @@ -95,10 +95,10 @@ def with_scope(locator) end Then /^(?:|I )should not see "([^"]*)"(?: within "([^"]*)")?$/ do |text, selector| - with_scope(selector) { expect(page).not_to have_text(text) } + with_scope(selector) { expect(page).to have_no_text(text) } end -Then %r{^(?:|I )should not see \/([^\/]*)\/(?: within "([^"]*)")?$} do |regexp, selector| +Then %r{^(?:|I )should not see /([^\/]*)/(?: within "([^"]*)")?$} do |regexp, selector| regexp = Regexp.new(regexp) with_scope(selector) { assert page.has_no_xpath?('//*', text: regexp) } end @@ -180,5 +180,5 @@ def with_scope(locator) end When 'I click the header {string}' do |text| - find('th', text: text).click + find('th', text:).click end diff --git a/features/support/step_definitions/xml_steps.rb b/features/support/step_definitions/xml_steps.rb index d0662b1454..bf2c6cb904 100644 --- a/features/support/step_definitions/xml_steps.rb +++ b/features/support/step_definitions/xml_steps.rb @@ -49,7 +49,7 @@ def assert_xml_strings_equal(str1, str2) page.driver.get(path_to(page_name), nil, 'HTTP_ACCEPT' => 'application/xml') end -When %r{^I (POST|PUT) the following XML to "(\/[^"]+)":$} do |action, path, xml| +When %r{^I (POST|PUT) the following XML to "(/[^"]+)":$} do |action, path, xml| page.driver.send( action.downcase, path.to_s, diff --git a/lib/ability_analysis.rb b/lib/ability_analysis.rb index fa80b1c729..8043e53c1d 100644 --- a/lib/ability_analysis.rb +++ b/lib/ability_analysis.rb @@ -73,7 +73,7 @@ def initialize(permissions: BASE_ABILITIES, roles: Role.keys, ability: Ability) end def generate_spec(output = $stdout) - AbilityAnalysis::SpecGenerator.new(self, output: output).generate + AbilityAnalysis::SpecGenerator.new(self, output:).generate end def abilities_for(user) diff --git a/lib/ability_analysis/spec_generator.rb b/lib/ability_analysis/spec_generator.rb index f1c189180d..4bd3400072 100644 --- a/lib/ability_analysis/spec_generator.rb +++ b/lib/ability_analysis/spec_generator.rb @@ -42,12 +42,12 @@ def generate # rubocop:todo Metrics/MethodLength private def generate_permissions_list(name, permissions_to_list, indent: 2) - output "let(:#{name}) do", indent: indent + output("let(:#{name}) do", indent:) output '{', indent: indent + 2 list = permissions_to_list.map { |klass, permissions| "#{klass} => %i[#{permissions.join(' ')}]" }.join(",\n") output list, indent: indent + 4 output '}', indent: indent + 2 - output 'end', indent: indent + output 'end', indent: end def generate_shared_example @@ -107,7 +107,7 @@ def generate_for(role) generate_authorized_models(role) output user = user_with_roles(role) - generate_tests(user, role: role) + generate_tests(user, role:) output 'end', indent: 2 end diff --git a/lib/accession/accession/sample.rb b/lib/accession/accession/sample.rb index dd5e1924e0..72549ca54a 100644 --- a/lib/accession/accession/sample.rb +++ b/lib/accession/accession/sample.rb @@ -36,7 +36,7 @@ def name end def title - @title ||= (sample.sample_metadata.sample_public_name || sample.sanger_sample_id) + @title ||= sample.sample_metadata.sample_public_name || sample.sanger_sample_id end # rubocop:todo Metrics/MethodLength diff --git a/lib/accession/accession/submission.rb b/lib/accession/accession/submission.rb index b2ec709b9a..d7df065e8d 100644 --- a/lib/accession/accession/submission.rb +++ b/lib/accession/accession/submission.rb @@ -73,8 +73,8 @@ def initialize(accessionables) end end - def each(&block) - files.each(&block) + def each(&) + files.each(&) end def open diff --git a/lib/accession/accession/tag_list.rb b/lib/accession/accession/tag_list.rb index eba8db0f00..d2eff93c67 100644 --- a/lib/accession/accession/tag_list.rb +++ b/lib/accession/accession/tag_list.rb @@ -24,8 +24,8 @@ def initialize(tags = {}) yield self if block_given? end - def each(&block) - tags.each(&block) + def each(&) + tags.each(&) end def required_for(service) diff --git a/lib/authenticated_test_helper.rb b/lib/authenticated_test_helper.rb index d4d106f8f6..dfbcbeaaec 100644 --- a/lib/authenticated_test_helper.rb +++ b/lib/authenticated_test_helper.rb @@ -40,8 +40,8 @@ def assert_difference(object, method = nil, difference = 1) assert_equal initial_value + difference, object.send(method), "#{object}##{method}" end - def assert_no_difference(object, method, &block) - assert_difference object, method, 0, &block + def assert_no_difference(object, method, &) + assert_difference(object, method, 0, &) end # Assert the block redirects to the login @@ -81,10 +81,10 @@ def check raise NotImplementedError end - def method_missing(method, *args) + def method_missing(method, *) @controller.reset! authenticate - @controller.send(method, *args) + @controller.send(method, *) check end end diff --git a/lib/capybara_failure_logger.rb b/lib/capybara_failure_logger.rb index 5495b4d441..c6fc96aecd 100644 --- a/lib/capybara_failure_logger.rb +++ b/lib/capybara_failure_logger.rb @@ -24,13 +24,13 @@ def self.log_failure(name, page, &block) log_js(name, page, &block) end - def self.log_screenshot(name, page, &block) + def self.log_screenshot(name, page, &) return unless page.respond_to?(:save_screenshot) page.save_screenshot("#{name}.png") filename = "#{Capybara.save_path}/#{name}.png" yield "📸 Screenshot saved to #{filename}" - output_image(filename, &block) + output_image(filename, &) rescue Capybara::NotSupportedByDriverError yield 'Could not save screenshot - Unsupported by this webdriver' end diff --git a/lib/eventful_mailer.rb b/lib/eventful_mailer.rb index d9b4d20526..aa105d6858 100644 --- a/lib/eventful_mailer.rb +++ b/lib/eventful_mailer.rb @@ -6,7 +6,7 @@ def confirm_event(receiver, eventful, message, content, _milestone, sent_at = Ti @message = message @content = content mail( - from: (configatron.sequencescape_email).to_s, + from: configatron.sequencescape_email.to_s, subject: "#{configatron.mail_prefix} #{eventful.class} #{eventful.id}: #{message}", bcc: receiver, sent_on: sent_at @@ -20,7 +20,7 @@ def update_event(receiver, study, title, content, sent_at = Time.zone.now) @message = title @content = content mail( - from: (configatron.sequencescape_email).to_s, + from: configatron.sequencescape_email.to_s, subject: "#{configatron.mail_prefix} Study #{study.id}: #{title}", bcc: receiver, sent_on: sent_at @@ -34,7 +34,7 @@ def confirm_sample_event(receiver, eventful, message, content, _milestone, sent_ @message = message @content = content mail( - from: (configatron.sequencescape_email).to_s, + from: configatron.sequencescape_email.to_s, subject: "#{configatron.mail_prefix} #{eventful.class} #{eventful.id}: #{message}", bcc: receiver, sent_on: sent_at @@ -46,7 +46,7 @@ def notify_request_fail(receiver, item, request, message, sent_at = Time.zone.no @request = request @message = message mail( - from: (configatron.sequencescape_email).to_s, + from: configatron.sequencescape_email.to_s, subject: "#{configatron.mail_prefix} Request failure for item #{item.id}", bcc: receiver, sent_on: sent_at @@ -56,7 +56,7 @@ def notify_request_fail(receiver, item, request, message, sent_at = Time.zone.no def fail_attempt(receiver, request, sent_at = Time.zone.now) @request = request mail( - from: (configatron.sequencescape_email).to_s, + from: configatron.sequencescape_email.to_s, subject: "#{configatron.mail_prefix} Attempt fail for #{request.id}", bcc: receiver, sent_on: sent_at @@ -70,7 +70,7 @@ def confirm_external_release_event(receiver, eventful, message, content, _milest @message = message @content = content mail( - from: (configatron.sequencescape_email).to_s, + from: configatron.sequencescape_email.to_s, subject: "#{configatron.mail_prefix} #{eventful.class} #{eventful.id}: #{message}", bcc: receiver, sent_on: sent_at diff --git a/lib/eventful_record.rb b/lib/eventful_record.rb index a78ac30c25..135c01ed3c 100644 --- a/lib/eventful_record.rb +++ b/lib/eventful_record.rb @@ -22,17 +22,17 @@ def #{name}(*args) end end - def has_many_lab_events(&block) - has_many(:lab_events, -> { order(created_at: :asc, id: :asc) }, as: :eventful, dependent: :destroy, &block) + def has_many_lab_events(&) + has_many(:lab_events, -> { order(created_at: :asc, id: :asc) }, as: :eventful, dependent: :destroy, &) end - def has_one_event_with_family(event_family, &block) + def has_one_event_with_family(event_family, &) has_one( :"#{event_family}_event", lambda { order(id: :desc).where(family: event_family) }, class_name: 'Event', as: :eventful, - &block + & ) end end diff --git a/lib/informatics/test/helpers/authentication_helper.rb b/lib/informatics/test/helpers/authentication_helper.rb index 26dce88c76..44b340afc4 100644 --- a/lib/informatics/test/helpers/authentication_helper.rb +++ b/lib/informatics/test/helpers/authentication_helper.rb @@ -40,8 +40,8 @@ def assert_difference(object, method = nil, difference = 1) assert_equal initial_value + difference, object.send(method), "#{object}##{method}" end - def assert_no_difference(object, method, &block) - assert_difference object, method, 0, &block + def assert_no_difference(object, method, &) + assert_difference(object, method, 0, &) end # Assert the block redirects to the login @@ -81,10 +81,10 @@ def check raise NotImplementedError end - def method_missing(method, *args) + def method_missing(method, *) @controller.reset! authenticate - @controller.send(method, *args) + @controller.send(method, *) check end end diff --git a/lib/lab_where_client.rb b/lib/lab_where_client.rb index d34683d23b..65f1b54aa1 100644 --- a/lib/lab_where_client.rb +++ b/lib/lab_where_client.rb @@ -34,7 +34,7 @@ def post(instance, target, payload) rescue Errno::ECONNREFUSED, RestClient::NotFound => e raise LabwhereException.new(e), 'LabWhere service is down', e.backtrace rescue RestClient::UnprocessableEntity => e - return parse_json(e.response) + parse_json(e.response) end def put(instance, target, payload) @@ -113,7 +113,7 @@ class LabwareSearch < Endpoint def self.find_locations_by_barcodes(barcodes) return nil if barcodes.blank? - payload = { barcodes: barcodes } + payload = { barcodes: } attrs = LabWhere.new.post(self, '', payload) new(attrs) unless attrs.nil? diff --git a/lib/label_printer/label_printer/label/robot_beds.rb b/lib/label_printer/label_printer/label/robot_beds.rb index f2558c2cd5..5393e343ed 100644 --- a/lib/label_printer/label_printer/label/robot_beds.rb +++ b/lib/label_printer/label_printer/label/robot_beds.rb @@ -13,7 +13,7 @@ def top_right(bed) end def bottom_right(bed) - (bed.ean13_barcode).to_s + bed.ean13_barcode.to_s end end end diff --git a/lib/limber/helper.rb b/lib/limber/helper.rb index f8fd60aa9a..6b480ac345 100644 --- a/lib/limber/helper.rb +++ b/lib/limber/helper.rb @@ -39,7 +39,7 @@ class TemplateConstructor # # @return [Array] An array of all matching submission templates. def self.find_for(name, sequencing = nil) - tc = TemplateConstructor.new(name: name, sequencing: sequencing) + tc = TemplateConstructor.new(name:, sequencing:) [true, false].map do |cherrypick| tc.sequencing.map do |sequencing_request_type| SubmissionTemplate.find_by!(name: tc.name_for(cherrypick, sequencing_request_type)) @@ -175,8 +175,8 @@ def each_submission_template name: name_for(cherrypick, sequencing_request_type), submission_class_name: 'LinearSubmission', submission_parameters: submission_parameters(cherrypick, sequencing_request_type), - superceded_by_id:, - product_line_id:, + superceded_by_id: superceded_by_id, + product_line_id: product_line_id, product_catalogue: catalogue } ) @@ -187,7 +187,7 @@ def each_submission_template def submission_parameters(cherrypick, sequencing) { request_type_ids_list: request_type_ids(cherrypick, sequencing), - order_role_id: OrderRole.find_or_create_by(role: role).id + order_role_id: OrderRole.find_or_create_by(role:).id } end end @@ -237,10 +237,10 @@ def request_type_ids(cherrypick, _sequencing) def self.find_project(name) if Rails.env.production? - Project.find_by!(name: name) + Project.find_by!(name:) else # In development mode or UAT we don't care so much - Project.find_by(name: name) || UatActions::StaticRecords.project + Project.find_by(name:) || UatActions::StaticRecords.project end end end diff --git a/lib/manifest_util.rb b/lib/manifest_util.rb index e810d7a622..efecc71f60 100644 --- a/lib/manifest_util.rb +++ b/lib/manifest_util.rb @@ -1,7 +1,7 @@ # frozen_string_literal: true module ManifestUtil def is_end_of_header?(row, pos) - ((pos != (row.length - 1)) && row[pos].blank? && row[pos + 1].blank?) + (pos != (row.length - 1)) && row[pos].blank? && row[pos + 1].blank? end def filter_end_of_header(header_row) diff --git a/lib/mbrave_tags_creator.rb b/lib/mbrave_tags_creator.rb index 09d9328cd8..795340da3f 100644 --- a/lib/mbrave_tags_creator.rb +++ b/lib/mbrave_tags_creator.rb @@ -26,9 +26,9 @@ def initialize(params) @yaml_contents = {} end - def log_line(&block) + def log_line(&) # We want to enforce that logs go to STDOUT while printing the barcodes - self.class.log_line(&block) + self.class.log_line(&) end def self.log_line @@ -176,7 +176,7 @@ def create_tag_plates(tag_layout_templates, user) # rubocop:todo Metrics/MethodL # rubocop:enable Metrics/AbcSize def process_create_tag_plates(login, version) - user = User.find_by!(login: login) + user = User.find_by!(login:) tag_layout_templates = TagLayoutTemplate.select do |template| diff --git a/lib/psd_formatter.rb b/lib/psd_formatter.rb index 4d661bdf6d..ca93e7a8dd 100644 --- a/lib/psd_formatter.rb +++ b/lib/psd_formatter.rb @@ -4,7 +4,7 @@ require 'ostruct' class PsdFormatter < Syslog::Logger::Formatter - LINE_FORMAT = "(thread-%s) [%s] %5s -- : %s\n".freeze + LINE_FORMAT = "(thread-%s) [%s] %5s -- : %s\n" def initialize(deployment_info) # below line is included because it was unknown whether diff --git a/lib/record_loader/asset_shape_loader.rb b/lib/record_loader/asset_shape_loader.rb index e1fe8a8449..ccb582da5b 100644 --- a/lib/record_loader/asset_shape_loader.rb +++ b/lib/record_loader/asset_shape_loader.rb @@ -20,7 +20,7 @@ class AssetShapeLoader < ApplicationRecordLoader # @option options [String] :description_strategy The strategy for describing the plate # @option options [Array] :sizes The sizes of the plates to generate Maps for def create_or_update!(name, options) - config = { name: name }.merge(options.symbolize_keys) + config = { name: }.merge(options.symbolize_keys) # PlateMapGeneration expects a non-namespaced constant for # description_strategy. It adds "Map::" prefix to refer to a nested diff --git a/lib/record_loader/barcode_printer_type_loader.rb b/lib/record_loader/barcode_printer_type_loader.rb index 9f8e876b1b..2a2b8d50ba 100644 --- a/lib/record_loader/barcode_printer_type_loader.rb +++ b/lib/record_loader/barcode_printer_type_loader.rb @@ -11,7 +11,7 @@ class BarcodePrinterTypeLoader < ApplicationRecordLoader config_folder 'barcode_printer_types' def create_or_update!(name, options) - BarcodePrinterType.create_with(options).find_or_create_by!(name: name) + BarcodePrinterType.create_with(options).find_or_create_by!(name:) end end end diff --git a/lib/record_loader/flowcell_type_loader.rb b/lib/record_loader/flowcell_type_loader.rb index fe6143beca..598d026830 100644 --- a/lib/record_loader/flowcell_type_loader.rb +++ b/lib/record_loader/flowcell_type_loader.rb @@ -10,7 +10,7 @@ class FlowcellTypeLoader < ApplicationRecordLoader config_folder 'flowcell_types' def create_or_update!(name, options) - FlowcellType.create_with(options).find_or_create_by!(name: name) + FlowcellType.create_with(options).find_or_create_by!(name:) end end end diff --git a/lib/record_loader/library_type_loader.rb b/lib/record_loader/library_type_loader.rb index 4818743062..def91ef0c2 100644 --- a/lib/record_loader/library_type_loader.rb +++ b/lib/record_loader/library_type_loader.rb @@ -10,7 +10,7 @@ class LibraryTypeLoader < ApplicationRecordLoader config_folder 'library_types' def create_or_update!(name, options) - LibraryType.create_with(options).find_or_create_by!(name: name) + LibraryType.create_with(options).find_or_create_by!(name:) end def names diff --git a/lib/record_loader/pipeline_loader.rb b/lib/record_loader/pipeline_loader.rb index e74f78f56b..4c027673ee 100644 --- a/lib/record_loader/pipeline_loader.rb +++ b/lib/record_loader/pipeline_loader.rb @@ -49,7 +49,7 @@ def create_or_update!(name, options) request_type_keys = obj.delete('request_type_keys') raise 'Request type keys not found' if request_type_keys.blank? request_types = RequestType.where(key: request_type_keys) - Pipeline.create_with(obj.merge(workflow: wf, request_types: request_types)).find_or_create_by!(name: name) + Pipeline.create_with(obj.merge(workflow: wf, request_types: request_types)).find_or_create_by!(name:) return unless name == 'NovaSeqX PE' diff --git a/lib/record_loader/pipeline_request_information_type_loader.rb b/lib/record_loader/pipeline_request_information_type_loader.rb index 99b4837037..a185e78825 100644 --- a/lib/record_loader/pipeline_request_information_type_loader.rb +++ b/lib/record_loader/pipeline_request_information_type_loader.rb @@ -12,11 +12,11 @@ class PipelineRequestInformationTypeLoader < ApplicationRecordLoader def create_or_update!(_name, options) pipeline = Pipeline.find_by!(name: options['pipeline_name']) - req_inf_type = RequestInformationType.find_by!(key: options['request_information_type_key']) - PipelineRequestInformationType.create_with( - pipeline: pipeline, - request_information_type: req_inf_type - ).find_or_create_by!(pipeline: pipeline, request_information_type: req_inf_type) + request_information_type = RequestInformationType.find_by!(key: options['request_information_type_key']) + PipelineRequestInformationType.create_with(pipeline:, request_information_type:).find_or_create_by!( + pipeline:, + request_information_type: + ) end end end diff --git a/lib/record_loader/plate_type_loader.rb b/lib/record_loader/plate_type_loader.rb index 94142d9c9a..00b347d829 100644 --- a/lib/record_loader/plate_type_loader.rb +++ b/lib/record_loader/plate_type_loader.rb @@ -11,7 +11,7 @@ class PlateTypeLoader < ApplicationRecordLoader config_folder 'plate_types' def create_or_update!(name, options) - PlateType.create_with(options).find_or_create_by!(name: name) + PlateType.create_with(options).find_or_create_by!(name:) end end end diff --git a/lib/record_loader/primer_panel_loader.rb b/lib/record_loader/primer_panel_loader.rb index 646ccdb4b2..e16a340bc6 100644 --- a/lib/record_loader/primer_panel_loader.rb +++ b/lib/record_loader/primer_panel_loader.rb @@ -11,7 +11,7 @@ class PrimerPanelLoader < ApplicationRecordLoader config_folder 'primer_panels' def create_or_update!(name, options) - PrimerPanel.create_with(options).find_or_create_by!(name: name) + PrimerPanel.create_with(options).find_or_create_by!(name:) end end end diff --git a/lib/record_loader/product_catalogue_loader.rb b/lib/record_loader/product_catalogue_loader.rb index 087a8c7993..a403bad828 100644 --- a/lib/record_loader/product_catalogue_loader.rb +++ b/lib/record_loader/product_catalogue_loader.rb @@ -10,7 +10,7 @@ class ProductCatalogueLoader < ApplicationRecordLoader config_folder 'product_catalogues' def create_or_update!(name, options) - ProductCatalogue.create_with(options).find_or_create_by!(name: name) + ProductCatalogue.create_with(options).find_or_create_by!(name:) end end end diff --git a/lib/record_loader/request_information_type_loader.rb b/lib/record_loader/request_information_type_loader.rb index ab7a314090..dbe80126a8 100644 --- a/lib/record_loader/request_information_type_loader.rb +++ b/lib/record_loader/request_information_type_loader.rb @@ -10,7 +10,7 @@ class RequestInformationTypeLoader < ApplicationRecordLoader config_folder 'request_information_types' def create_or_update!(key, options) - RequestInformationType.create_with(options).find_or_create_by!(key: key) + RequestInformationType.create_with(options).find_or_create_by!(key:) end end end diff --git a/lib/record_loader/request_type_loader.rb b/lib/record_loader/request_type_loader.rb index 07417756cc..2fe19c728a 100644 --- a/lib/record_loader/request_type_loader.rb +++ b/lib/record_loader/request_type_loader.rb @@ -12,7 +12,7 @@ class RequestTypeLoader < ApplicationRecordLoader def create_or_update!(key, options) RequestType .create_with(filter_options(options)) - .find_or_create_by!(key: key) + .find_or_create_by!(key:) .tap do |request_type| add_library_types(request_type, options.fetch('library_types', [])) add_acceptable_purposes(request_type, options.fetch('acceptable_purposes', [])) @@ -26,7 +26,7 @@ def create_or_update!(key, options) def add_library_types(request_type, library_types) rt_lts = request_type.library_types.pluck(:name) library_types.each do |name| - request_type.library_types << LibraryType.find_or_create_by!(name: name) unless rt_lts.include?(name) + request_type.library_types << LibraryType.find_or_create_by!(name:) unless rt_lts.include?(name) end return if library_types.empty? || request_type.request_type_validators.exists?(request_option: 'library_type') @@ -39,7 +39,7 @@ def add_acceptable_purposes(request_type, purposes) purposes.each do |name| next if acceptable_purposes.include?(name) - request_type.acceptable_purposes << Purpose.find_by!(name: name) + request_type.acceptable_purposes << Purpose.find_by!(name:) end end diff --git a/lib/record_loader/request_type_validators_loader.rb b/lib/record_loader/request_type_validators_loader.rb index b23a6386a7..5ea0f2410e 100644 --- a/lib/record_loader/request_type_validators_loader.rb +++ b/lib/record_loader/request_type_validators_loader.rb @@ -12,7 +12,7 @@ class RequestTypeValidatorsLoader < ApplicationRecordLoader def create_or_update!(key, options) request_type_key = options.delete('request_type_key') rt = RequestType.find_by(key: request_type_key) - RequestType::Validator.create_with(options.merge(request_type_id: rt.id)).find_or_create_by!(key: key) + RequestType::Validator.create_with(options.merge(request_type_id: rt.id)).find_or_create_by!(key:) end end end diff --git a/lib/record_loader/robot_loader.rb b/lib/record_loader/robot_loader.rb index c2ea96d09b..97edb797e1 100644 --- a/lib/record_loader/robot_loader.rb +++ b/lib/record_loader/robot_loader.rb @@ -9,7 +9,7 @@ class RobotLoader < ApplicationRecordLoader config_folder 'robots' def create_or_update!(name, options) - Robot.create_with(options).find_or_create_by!(name: name) + Robot.create_with(options).find_or_create_by!(name:) end end end diff --git a/lib/record_loader/robot_property_loader.rb b/lib/record_loader/robot_property_loader.rb index db7890d68e..ac88c8fd25 100644 --- a/lib/record_loader/robot_property_loader.rb +++ b/lib/record_loader/robot_property_loader.rb @@ -10,7 +10,7 @@ class RobotPropertyLoader < ApplicationRecordLoader def create_or_update!(name, options) # find the robot by name - r = Robot.find_by(name: name) + r = Robot.find_by(name:) return if r.blank? # find or create each property diff --git a/lib/record_loader/submission_template_loader.rb b/lib/record_loader/submission_template_loader.rb index 340f840352..6fcf21241f 100644 --- a/lib/record_loader/submission_template_loader.rb +++ b/lib/record_loader/submission_template_loader.rb @@ -13,7 +13,7 @@ def create_or_update!(name, options) derived_options = generate_derived_options(options['related_records']) final_options = options.except('related_records').merge(derived_options) - SubmissionTemplate.create_with(final_options).find_or_create_by!(name: name) + SubmissionTemplate.create_with(final_options).find_or_create_by!(name:) end def generate_derived_options(related_records) @@ -43,19 +43,19 @@ def sort_request_type_ids(request_type_keys) def find_project(name) if Rails.env.production? - Project.find_by!(name: name) + Project.find_by!(name:) else # In development mode or UAT we don't care so much - Project.find_by(name: name) || UatActions::StaticRecords.project + Project.find_by(name:) || UatActions::StaticRecords.project end end def find_study(name) if Rails.env.production? - Study.find_by!(name: name) + Study.find_by!(name:) else # In development mode or UAT we don't care so much - Study.find_by(name: name) || UatActions::StaticRecords.study + Study.find_by(name:) || UatActions::StaticRecords.study end end end diff --git a/lib/record_loader/tag_group_adapter_type_loader.rb b/lib/record_loader/tag_group_adapter_type_loader.rb index 14799d0aef..f513c3256b 100644 --- a/lib/record_loader/tag_group_adapter_type_loader.rb +++ b/lib/record_loader/tag_group_adapter_type_loader.rb @@ -11,7 +11,7 @@ class TagGroupAdapterTypeLoader < ApplicationRecordLoader config_folder 'tag_group_adapter_types' def create_or_update!(name, _options) - TagGroup::AdapterType.find_or_create_by!(name: name) + TagGroup::AdapterType.find_or_create_by!(name:) end end end diff --git a/lib/record_loader/tag_group_loader.rb b/lib/record_loader/tag_group_loader.rb index 736ab36df6..72cca14402 100644 --- a/lib/record_loader/tag_group_loader.rb +++ b/lib/record_loader/tag_group_loader.rb @@ -15,9 +15,9 @@ def create_or_update!(name, options) TagGroup .create_with(options) - .find_or_create_by!(name: name) + .find_or_create_by!(name:) .tap do |tag_group| - tag_attributes = tags.map { |map_id, oligo| { map_id: map_id, oligo: oligo } } + tag_attributes = tags.map { |map_id, oligo| { map_id:, oligo: } } tag_group.tags.import(tag_attributes) if tag_group.tags.empty? end end diff --git a/lib/record_loader/tag_layout_templates_loader.rb b/lib/record_loader/tag_layout_templates_loader.rb index eab58d488d..9aa7248c82 100644 --- a/lib/record_loader/tag_layout_templates_loader.rb +++ b/lib/record_loader/tag_layout_templates_loader.rb @@ -11,7 +11,7 @@ class TagLayoutTemplatesLoader < ApplicationRecordLoader config_folder 'tag_layout_templates' def create_or_update!(name, options) - TagLayoutTemplate.create_with(options).find_or_create_by!(name: name) + TagLayoutTemplate.create_with(options).find_or_create_by!(name:) end end end diff --git a/lib/record_loader/tag_set_loader.rb b/lib/record_loader/tag_set_loader.rb index 010c8bf68f..29f0aeb04a 100644 --- a/lib/record_loader/tag_set_loader.rb +++ b/lib/record_loader/tag_set_loader.rb @@ -11,7 +11,7 @@ class TagSetLoader < ApplicationRecordLoader config_folder 'tag_sets' def create_or_update!(name, options) - TagSet.create_with(options).find_or_create_by!(name: name) + TagSet.create_with(options).find_or_create_by!(name:) end end end diff --git a/lib/record_loader/transfer_template_loader.rb b/lib/record_loader/transfer_template_loader.rb index e8935e9de0..5638eea8cb 100644 --- a/lib/record_loader/transfer_template_loader.rb +++ b/lib/record_loader/transfer_template_loader.rb @@ -13,7 +13,7 @@ def create_or_update!(name, options) # TransferTemplate.create_with(options).find_or_create_by!(name: name) # We use the following because it creates a new record or updates existing. - transfer_template = TransferTemplate.find_or_initialize_by(name: name) + transfer_template = TransferTemplate.find_or_initialize_by(name:) transfer_template.update!(options) # assign_attributes and save! end end diff --git a/lib/record_loader/tube_purpose_loader.rb b/lib/record_loader/tube_purpose_loader.rb index dc4ab8dbab..927b2f6a1f 100644 --- a/lib/record_loader/tube_purpose_loader.rb +++ b/lib/record_loader/tube_purpose_loader.rb @@ -11,7 +11,7 @@ class TubePurposeLoader < ApplicationRecordLoader config_folder 'tube_purposes' def create_or_update!(name, options) - Tube::Purpose.create_with(options).find_or_create_by!(name: name) + Tube::Purpose.create_with(options).find_or_create_by!(name:) end end end diff --git a/lib/record_loader/tube_rack_purpose_loader.rb b/lib/record_loader/tube_rack_purpose_loader.rb index 642d156e4f..e1c2e2e13d 100644 --- a/lib/record_loader/tube_rack_purpose_loader.rb +++ b/lib/record_loader/tube_rack_purpose_loader.rb @@ -15,7 +15,7 @@ class TubeRackPurposeLoader < ApplicationRecordLoader def create_or_update!(name, options) options['target_type'] = DEFAULT_TARGET_TYPE options['barcode_printer_type'] = barcode_printer_type(options['barcode_printer_type']) - TubeRack::Purpose.create_with(options).find_or_create_by!(name: name) + TubeRack::Purpose.create_with(options).find_or_create_by!(name:) end def barcode_printer_type(name) diff --git a/lib/record_loader/workflow_loader.rb b/lib/record_loader/workflow_loader.rb index e5a26dffca..6872b5fc38 100644 --- a/lib/record_loader/workflow_loader.rb +++ b/lib/record_loader/workflow_loader.rb @@ -10,7 +10,7 @@ class WorkflowLoader < ApplicationRecordLoader config_folder 'workflows' def create_or_update!(name, options) - Workflow.create_with(options).find_or_create_by!(name: name) + Workflow.create_with(options).find_or_create_by!(name:) end end end diff --git a/lib/request_class_deprecator.rb b/lib/request_class_deprecator.rb index 1c87ff82cf..ac5547fa7d 100644 --- a/lib/request_class_deprecator.rb +++ b/lib/request_class_deprecator.rb @@ -26,7 +26,7 @@ def deprecate_class(request_class_name, options = {}) # rubocop:todo Metrics/Abc ActiveRecord::Base.transaction do RequestType - .where(request_class_name: request_class_name) + .where(request_class_name:) .find_each do |rt| say "Deprecating: #{rt.name}" rt.update!(deprecated: true) diff --git a/lib/submission_serializer.rb b/lib/submission_serializer.rb index 8fdf5716e3..9bc81ba9e6 100644 --- a/lib/submission_serializer.rb +++ b/lib/submission_serializer.rb @@ -85,7 +85,7 @@ def self.construct!(hash) # rubocop:todo Metrics/CyclomaticComplexity end sp[:request_type_ids_list] = ensp[:request_types].map do |rtk| - [(RequestType.find_by(key: rtk).try(:id) || raise(StandardError, "Could not find #{rtk}"))] + [RequestType.find_by(key: rtk).try(:id) || raise(StandardError, "Could not find #{rtk}")] end sp[:order_role_id] = OrderRole.find_or_create_by(role: ensp[:order_role]).id if ensp[:order_role] diff --git a/lib/tasks/hic_library_types.rake b/lib/tasks/hic_library_types.rake index d8d45350e9..a413712d59 100644 --- a/lib/tasks/hic_library_types.rake +++ b/lib/tasks/hic_library_types.rake @@ -8,9 +8,9 @@ namespace :hic_library_types do request_types = hic_library_type.request_types ['Hi-C - Arima v2', 'Hi-C – Qiagen', 'Hi-C – OmniC', 'Hi-C – Arima v1', 'Hi-C – Dovetail'].each do |name| - next if LibraryType.find_by(name: name) + next if LibraryType.find_by(name:) - LibraryType.create!(name: name, request_types: request_types) + LibraryType.create!(name:, request_types:) puts "Library type created for #{name}" end end diff --git a/lib/tasks/insdc/import_countries.rake b/lib/tasks/insdc/import_countries.rake index ea5a119aab..f17d4f454c 100644 --- a/lib/tasks/insdc/import_countries.rake +++ b/lib/tasks/insdc/import_countries.rake @@ -1,20 +1,24 @@ # frozen_string_literal: true # Control the defaults to use. Please remember to update sample_checklist if necessary -INSDC_COUNTRIES_DEFAULTS = { - ena_root: 'https://www.ebi.ac.uk/ena/browser/api/xml/', - sample_checklist: 'ERC000011' -}.freeze +unless defined?(INSDC_COUNTRIES_DEFAULTS) + INSDC_COUNTRIES_DEFAULTS = { + ena_root: 'https://www.ebi.ac.uk/ena/browser/api/xml/', + sample_checklist: 'ERC000011' + }.freeze +end # Sets the default priorities. Resisting the temptation to put this in a yaml file for now. # Higher priorities are sorted towards the top of the list -INSDC_COUNTRIES_PRIORITIES = { - 'not provided' => 2, - 'United Kingdom' => 1, - 'not applicable' => -1, - 'not collected' => -1, - 'restricted access' => -1 -}.freeze +unless defined?(INSDC_COUNTRIES_PRIORITIES) + INSDC_COUNTRIES_PRIORITIES = { + 'not provided' => 2, + 'United Kingdom' => 1, + 'not applicable' => -1, + 'not collected' => -1, + 'restricted access' => -1 + }.freeze +end namespace :insdc do namespace :countries do diff --git a/lib/tasks/limber.rake b/lib/tasks/limber.rake index adfff1264c..c20b04fcd1 100644 --- a/lib/tasks/limber.rake +++ b/lib/tasks/limber.rake @@ -138,7 +138,7 @@ namespace :limber do # rubocop:todo Metrics/BlockLength ActiveRecord::Base.transaction do st_params.each do |prefix, params| - catalogue_name = (params[:catalogue_name] || prefix) + catalogue_name = params[:catalogue_name] || prefix catalogue = ProductCatalogue.create_with(selection_behaviour: 'SingleProduct').find_or_create_by!(name: catalogue_name) Limber::Helper::TemplateConstructor.new( @@ -147,8 +147,8 @@ namespace :limber do sequencing_keys: params[:sequencing_list] ).build! unless params[:omit_library_templates] - Limber::Helper::LibraryOnlyTemplateConstructor.new(prefix: prefix, catalogue: catalogue).build! - Limber::Helper::LibraryAndMultiplexingTemplateConstructor.new(prefix: prefix, catalogue: catalogue).build! + Limber::Helper::LibraryOnlyTemplateConstructor.new(prefix:, catalogue:).build! + Limber::Helper::LibraryAndMultiplexingTemplateConstructor.new(prefix:, catalogue:).build! end end diff --git a/lib/tasks/populate_number_of_samples_per_pool.rake b/lib/tasks/populate_number_of_samples_per_pool.rake new file mode 100644 index 0000000000..9e779feaee --- /dev/null +++ b/lib/tasks/populate_number_of_samples_per_pool.rake @@ -0,0 +1,42 @@ +# frozen_string_literal: true + +# Run the rake task with the following command: +# bundle exec rake number_of_samples_per_pool:populate[20,1] +# The rake task will populate the number of samples per pool column in the request_metadata table +# for a given submission ID. +namespace :number_of_samples_per_pool do + desc 'Populate number of samples per pool column in request_metadata table for a given submission ID' + + task :populate, %i[samples_per_pool submission_id] => :environment do |_, args| + args.with_defaults(samples_per_pool: nil, submission_id: nil) + + raise StandardError, 'Number of samples per pool is missing' if args[:samples_per_pool].nil? + raise StandardError, 'Submission ID is missing' if args[:submission_id].nil? + + puts "Populating number of samples per pool column with #{args[:samples_per_pool]} + in request_metadata table for submission: #{args[:submission_id]}..." + + ActiveRecord::Base.transaction do + saved_count = 0 + Request::Metadata + .joins(:request) + .where(requests: { submission_id: args[:submission_id] }) + .find_each(batch_size: 50) do |request_metadata| + puts "Processing request_metadata #{request_metadata.id}..." + saved_count = process_request_metadata(request_metadata, saved_count, args[:samples_per_pool]) + end + end + end + + def process_request_metadata(request_metadata, saved_count, samples_per_pool) + request_metadata.number_of_samples_per_pool = samples_per_pool + begin + request_metadata.save! + saved_count += 1 + rescue ActiveRecord::ActiveRecordError, StandardError => e + puts "Error processing request_metadata #{request_metadata.id}: #{e.message}" + raise e + end + saved_count + end +end diff --git a/lib/tasks/register_auto_imported_samples_as_stock.rake b/lib/tasks/register_auto_imported_samples_as_stock.rake index a61c168dc2..930b940b6e 100644 --- a/lib/tasks/register_auto_imported_samples_as_stock.rake +++ b/lib/tasks/register_auto_imported_samples_as_stock.rake @@ -36,8 +36,7 @@ namespace :auto_imported_samples do labware = labware_samples.uniq # 890 in training 2020-07-07 puts "labware count: #{labware.count}" - receptacles = - Receptacle.where(labware: labware).joins(:aliquots).where("aliquots.study_id IN (#{relevant_study_ids})") + receptacles = Receptacle.where(labware:).joins(:aliquots).where("aliquots.study_id IN (#{relevant_study_ids})") # 78,507 in training 2020-07-08 (85,440 before join with aliquots) puts "receptacles count: #{receptacles.count}" diff --git a/lib/tasks/retention_instructions.rake b/lib/tasks/retention_instructions.rake index dcf0ef5acc..d4fb68c821 100644 --- a/lib/tasks/retention_instructions.rake +++ b/lib/tasks/retention_instructions.rake @@ -24,7 +24,7 @@ namespace :retention_instructions do } ) labwares = labwares.limit(limit) unless limit.nil? - labwares.find_each(batch_size: batch_size) do |labware| + labwares.find_each(batch_size:) do |labware| puts "Processing labware #{labware.id}: #{labware.name}..." saved_count = process_labware(labware, saved_count) end diff --git a/lib/tasks/support/remove_duplicate_asset_links.rake b/lib/tasks/support/remove_duplicate_asset_links.rake new file mode 100644 index 0000000000..489b1eeb0b --- /dev/null +++ b/lib/tasks/support/remove_duplicate_asset_links.rake @@ -0,0 +1,43 @@ +# frozen_string_literal: true + +namespace :support do + # This task needs to be executed before creating the unique-together index on + # the ancestor_id and descendant_id columns of the asset_links table. The + # index creation will be done using a migration. If there are already + # duplicate records, the migration will fail. This task fixes that by finding + # all the duplicate asset links and removes all but the most recently created + # one. The task requires an argument to save the removed duplicates to a file + # for auditing purposes. + desc 'Remove duplicate asset links' + task remove_duplicate_asset_links: :environment do |_t, args| + csv_file_path = args.extras.first # Positional argument. + if csv_file_path.nil? + puts "Usage: rake 'support:remove_duplicate_asset_links[csv_file_path]'" + exit 1 + end + + duplicates_removed = 0 + + ActiveRecord::Base.transaction do + CSV.open(Rails.root.join(csv_file_path), 'w') do |csv| + csv << AssetLink.column_names # Write the headers + AssetLink + .group(:ancestor_id, :descendant_id) + .having('count(*) > 1') + .each do |link| + duplicates = + AssetLink + .where(ancestor_id: link.ancestor_id, descendant_id: link.descendant_id) + .order(created_at: :desc) + .offset(1) # Except the most recent one. + duplicates.each { |duplicate| csv << duplicate.attributes.values } + duplicates.delete_all + duplicates_removed += duplicates.size + end + end + end + + Rails.logger.info("Removed #{duplicates_removed} duplicate asset links.") + puts "Deleted records have been exported to #{csv_file_path}" + end +end diff --git a/lib/working_setup/standard_seeder.rb b/lib/working_setup/standard_seeder.rb index f69fc2f2e3..9966b65906 100644 --- a/lib/working_setup/standard_seeder.rb +++ b/lib/working_setup/standard_seeder.rb @@ -46,7 +46,7 @@ def seed end def plates_of_purpose(name, number) # rubocop:todo Metrics/AbcSize - purpose = Purpose.find_by!(name: name) + purpose = Purpose.find_by!(name:) number.times do purpose.create!.tap do |plate| plate.wells.each do |w| @@ -110,7 +110,7 @@ def faculty_sponsor end def create_project(name) - existing = Project.find_by(name: name) + existing = Project.find_by(name:) return existing if existing Project.create!( @@ -126,7 +126,7 @@ def create_project(name) end def create_study(name) - existing = Study.find_by(name: name) + existing = Study.find_by(name:) return existing if existing Study.create!( diff --git a/package.json b/package.json index 0346bb98cc..7f11641e6b 100644 --- a/package.json +++ b/package.json @@ -47,11 +47,17 @@ "jest": "^26.6.3", "miragejs": "^0.1.48", "prettier": "^3.3.2", - "vite": "^5.3.2", + "vite": "^5.3.6", "vite-plugin-ruby": "^5.0.0", "vite-plugin-vue2": "^1.9.3", "vue-jest": "^3.0.7" }, + "_comment": "Required to address https://github.com/npm/cli/issues/4828", + "optionalDependencies": { + "@rollup/rollup-darwin-arm64": "*", + "@rollup/rollup-linux-x64-gnu": "*", + "@rollup/rollup-win32-x64-msvc": "*" + }, "scripts": { "test": "jest", "lint": "eslint --ext .js --ext .vue app/frontend", diff --git a/spec/api/api_root_spec.rb b/spec/api/api_root_spec.rb index da190b2974..34acd6b3e9 100644 --- a/spec/api/api_root_spec.rb +++ b/spec/api/api_root_spec.rb @@ -7,7 +7,7 @@ subject { '/api/1/' } describe '#get' do - let(:authorised_app) { create :api_application } + let(:authorised_app) { create(:api_application) } let(:response_body) do '{ @@ -389,7 +389,7 @@ end describe '#get unauthorized' do - let(:user) { create :user } + let(:user) { create(:user) } let(:response_body) do '{ diff --git a/spec/api/asset_audit_spec.rb b/spec/api/asset_audit_spec.rb index dd373e957d..be4e969006 100644 --- a/spec/api/asset_audit_spec.rb +++ b/spec/api/asset_audit_spec.rb @@ -4,8 +4,8 @@ require 'support/barcode_helper' describe '/api/1/asset_audits' do - let(:authorised_app) { create :api_application } - let(:labware) { create :tube } + let(:authorised_app) { create(:api_application) } + let(:labware) { create(:tube) } describe '#post' do subject(:resources) { '/api/1/asset_audits' } @@ -166,7 +166,7 @@ describe '#get' do subject(:resource) { "/api/1/#{asset_audit.uuid}" } - let(:asset_audit) { create :asset_audit } + let(:asset_audit) { create(:asset_audit) } let(:response_body) do { diff --git a/spec/api/dilution_plate_purpose_spec.rb b/spec/api/dilution_plate_purpose_spec.rb index 31222da6ad..454550f03d 100644 --- a/spec/api/dilution_plate_purpose_spec.rb +++ b/spec/api/dilution_plate_purpose_spec.rb @@ -4,10 +4,10 @@ require 'support/barcode_helper' describe '/api/1/plate-purpose-uuid' do - let(:authorised_app) { create :api_application } + let(:authorised_app) { create(:api_application) } let(:uuid) { '00000000-1111-2222-3333-444444444444' } - before { create :dilution_plate_purpose, :uuidable, uuid: uuid, name: 'Example purpose' } + before { create(:dilution_plate_purpose, :uuidable, uuid: uuid, name: 'Example purpose') } describe '#get' do subject(:url) { '/api/1/' + uuid } diff --git a/spec/api/extraction_attributes_spec.rb b/spec/api/extraction_attributes_spec.rb index f2465b5f14..a63003cdb5 100644 --- a/spec/api/extraction_attributes_spec.rb +++ b/spec/api/extraction_attributes_spec.rb @@ -6,14 +6,14 @@ describe '#post' do subject { "/api/1/#{target_plate.uuid}/extraction_attributes" } - let(:user) { create :user, login: 'test' } - let(:authorised_app) { create :api_application } - let(:target_plate) { create :plate_with_empty_wells } + let(:user) { create(:user, login: 'test') } + let(:authorised_app) { create(:api_application) } + let(:target_plate) { create(:plate_with_empty_wells) } let(:response_code) { 201 } it 'supports attributes update on a plate' do - sample_tube = create :sample_tube + sample_tube = create(:sample_tube) payload = "{ \"extraction_attribute\":{ @@ -29,8 +29,8 @@ end describe '#racking' do - let(:sample_tube) { create :sample_tube } - let(:sample_tube2) { create :sample_tube } + let(:sample_tube) { create(:sample_tube) } + let(:sample_tube2) { create(:sample_tube) } let(:source_tube1_uuid) { sample_tube.uuid } let(:source_tube2_uuid) { sample_tube2.uuid } @@ -67,7 +67,7 @@ context 'with a plate with wells' do subject { "/api/1/#{target_plate.uuid}/extraction_attributes" } - let(:target_plate) { create :plate_with_tagged_wells } + let(:target_plate) { create(:plate_with_tagged_wells) } let(:taget_well_a1) { target_plate.wells.located_at('A1').first } let(:taget_well_b1) { target_plate.wells.located_at('B1').first } @@ -78,8 +78,8 @@ end context 'when tubes contain the same samples as the wells' do - let(:sample_tube) { create :sample_tube, sample: taget_well_a1.samples.first } - let(:sample_tube2) { create :sample_tube, sample: taget_well_b1.samples.first } + let(:sample_tube) { create(:sample_tube, sample: taget_well_a1.samples.first) } + let(:sample_tube2) { create(:sample_tube, sample: taget_well_b1.samples.first) } it 'does not rack without error a tube in the well if the well already contains the sample for this tube' do authorized_api_request :post, subject, payload @@ -94,9 +94,9 @@ describe '#reracking' do subject { "/api/1/#{target_plate.uuid}/extraction_attributes" } - let(:previous_plate) { create :plate_with_tagged_wells } - let(:previous_plate2) { create :plate_with_tagged_wells } - let(:target_plate) { create :plate_with_empty_wells } + let(:previous_plate) { create(:plate_with_tagged_wells) } + let(:previous_plate2) { create(:plate_with_tagged_wells) } + let(:target_plate) { create(:plate_with_empty_wells) } let(:well1) { previous_plate.wells.first } let(:well2) { previous_plate2.wells.first } @@ -133,7 +133,7 @@ # rubocop:enable Layout/LineLength subject { "/api/1/#{target_plate.uuid}/extraction_attributes" } - let(:target_plate) { create :plate_with_tagged_wells } + let(:target_plate) { create(:plate_with_tagged_wells) } let(:well1) { target_plate.wells[0] } let(:well2) { target_plate.wells[1] } let(:well3) { target_plate.wells[2] } @@ -212,10 +212,10 @@ end describe '#racking + #reracking' do - let(:previous_plate) { create :plate_with_tagged_wells } - let(:previous_plate2) { create :plate_with_tagged_wells } - let(:sample_tube) { create :sample_tube } - let(:sample_tube2) { create :sample_tube } + let(:previous_plate) { create(:plate_with_tagged_wells) } + let(:previous_plate2) { create(:plate_with_tagged_wells) } + let(:sample_tube) { create(:sample_tube) } + let(:sample_tube2) { create(:sample_tube) } let(:well1) { previous_plate.wells.first } let(:well2) { previous_plate2.wells.first } @@ -254,12 +254,12 @@ end context 'in different requests' do - let(:second_plate) { create :plate_with_tagged_wells } + let(:second_plate) { create(:plate_with_tagged_wells) } let(:first_plate_subject) { "/api/1/#{first_plate.uuid}/extraction_attributes" } let(:second_plate_subject) { "/api/1/#{second_plate.uuid}/extraction_attributes" } - let(:sample_tube) { create :sample_tube } - let(:sample_tube2) { create :sample_tube } + let(:sample_tube) { create(:sample_tube) } + let(:sample_tube2) { create(:sample_tube) } let(:well1) { first_plate.wells.located_at('A1').first } let(:well2) { first_plate.wells.located_at('B1').first } @@ -294,7 +294,7 @@ end context 'with 2 plates with samples already' do - let(:first_plate) { create :plate_with_tagged_wells } + let(:first_plate) { create(:plate_with_tagged_wells) } context 'when performing a rerack from a position and then try to rack back' do it 'reracks to the second plate but fails to rack into the first plate' do @@ -333,7 +333,7 @@ end context 'with a first empty plate and second full plate' do - let(:first_plate) { create :plate_with_empty_wells } + let(:first_plate) { create(:plate_with_empty_wells) } it 'racks to the first plate and reracks to the second plate' do authorized_api_request :post, first_plate_subject, payload_rack diff --git a/spec/api/labware_spec.rb b/spec/api/labware_spec.rb index df81b2a8c1..f52d4f9301 100644 --- a/spec/api/labware_spec.rb +++ b/spec/api/labware_spec.rb @@ -4,12 +4,12 @@ require 'support/barcode_helper' describe '/api/1/labware-uuid' do - let(:authorised_app) { create :api_application } + let(:authorised_app) { create(:api_application) } let(:uuid) { labware.uuid } let(:custom_metadata_uuid) { collection.uuid } let(:purpose_uuid) { '00000000-1111-2222-3333-666666666666' } - let!(:labware) { create :labware } + let!(:labware) { create(:labware) } describe '#get' do subject(:url) { '/api/1/' + uuid } diff --git a/spec/api/multiplexed_library_tube_spec.rb b/spec/api/multiplexed_library_tube_spec.rb index 6c643ff792..1dd25e53b3 100644 --- a/spec/api/multiplexed_library_tube_spec.rb +++ b/spec/api/multiplexed_library_tube_spec.rb @@ -4,13 +4,13 @@ require 'support/barcode_helper' describe '/api/1/multiplexed-library-tube-uuid' do - let(:authorised_app) { create :api_application } + let(:authorised_app) { create(:api_application) } let(:uuid) { tube.uuid } let(:custom_metadata_uuid) { collection.uuid } let(:purpose_uuid) { '00000000-1111-2222-3333-666666666666' } - let(:purpose) { create :tube_purpose, :uuidable, uuid: purpose_uuid, name: 'Example purpose' } - let(:tube) { create :multiplexed_library_tube, purpose: purpose, volume: 8.76000000 } + let(:purpose) { create(:tube_purpose, :uuidable, uuid: purpose_uuid, name: 'Example purpose') } + let(:tube) { create(:multiplexed_library_tube, purpose: purpose, volume: 8.76000000) } let(:collection) { create(:custom_metadatum_collection, asset: tube) } before do diff --git a/spec/api/plate_purpose_spec.rb b/spec/api/plate_purpose_spec.rb index 9bf731c17c..fc21cecd01 100644 --- a/spec/api/plate_purpose_spec.rb +++ b/spec/api/plate_purpose_spec.rb @@ -6,8 +6,8 @@ describe '/api/1/plate_purposes' do subject { '/api/1/plate_purposes' } - let(:authorised_app) { create :api_application } - let(:parent_purpose) { create :plate_purpose } + let(:authorised_app) { create(:api_application) } + let(:parent_purpose) { create(:plate_purpose) } describe '#post' do let(:payload) do @@ -46,10 +46,10 @@ end describe '/api/1/plate-purpose-uuid' do - let(:authorised_app) { create :api_application } + let(:authorised_app) { create(:api_application) } let(:uuid) { '00000000-1111-2222-3333-444444444444' } - before { create :plate_purpose, :uuidable, uuid: uuid, name: 'Example purpose' } + before { create(:plate_purpose, :uuidable, uuid: uuid, name: 'Example purpose') } describe '#get' do subject { '/api/1/' + uuid } diff --git a/spec/api/plate_spec.rb b/spec/api/plate_spec.rb index 621d980c96..d90404c29a 100644 --- a/spec/api/plate_spec.rb +++ b/spec/api/plate_spec.rb @@ -6,10 +6,10 @@ describe '/api/1/plate-uuid' do subject { '/api/1/' + uuid } - let(:authorised_app) { create :api_application } + let(:authorised_app) { create(:api_application) } let(:uuid) { plate.uuid } - let(:plate) { create :plate, barcode: 'SQPD-1' } + let(:plate) { create(:plate, barcode: 'SQPD-1') } before { custom_metadata_collection } @@ -131,7 +131,7 @@ end let(:stock_plate) { create(:full_stock_plate, barcode: 'SQPD-2') } - let(:plate) { create :plate, parents: [stock_plate], barcode: 'SQPD-1' } + let(:plate) { create(:plate, parents: [stock_plate], barcode: 'SQPD-1') } let(:response_code) { 200 } it 'supports resource reading' do diff --git a/spec/api/qcable_creator_spec.rb b/spec/api/qcable_creator_spec.rb index af505b750f..a5ccde7327 100644 --- a/spec/api/qcable_creator_spec.rb +++ b/spec/api/qcable_creator_spec.rb @@ -5,9 +5,9 @@ describe '/api/1/qcable_creators' do subject { '/api/1/qcable_creators' } - let(:authorised_app) { create :api_application } - let(:user) { create :user } - let(:lot) { create :tag2_lot } + let(:authorised_app) { create(:api_application) } + let(:user) { create(:user) } + let(:lot) { create(:tag2_lot) } let(:barcodes) { %w[CGAP-1 CGAP-2 CGAP-3 CGAP-4 CGAP-5] } describe '#post' do diff --git a/spec/api/receptacle_spec.rb b/spec/api/receptacle_spec.rb index 4576d39feb..afe5dd313b 100644 --- a/spec/api/receptacle_spec.rb +++ b/spec/api/receptacle_spec.rb @@ -4,12 +4,12 @@ require 'support/barcode_helper' describe '/api/1/receptacle-uuid' do - let(:authorised_app) { create :api_application } + let(:authorised_app) { create(:api_application) } let(:uuid) { receptacle.uuid } let(:custom_metadata_uuid) { collection.uuid } let(:purpose_uuid) { '00000000-1111-2222-3333-666666666666' } - let(:receptacle) { create :receptacle } + let(:receptacle) { create(:receptacle) } describe '#get' do subject(:url) { '/api/1/' + uuid } diff --git a/spec/api/request_types_spec.rb b/spec/api/request_types_spec.rb index 3c3a4fa54b..7682f8b42b 100644 --- a/spec/api/request_types_spec.rb +++ b/spec/api/request_types_spec.rb @@ -4,10 +4,10 @@ require 'support/barcode_helper' describe '/api/1/request-type-uuid' do - let(:authorised_app) { create :api_application } + let(:authorised_app) { create(:api_application) } let(:uuid) { '00000000-1111-2222-3333-444444444444' } - before { create :request_type, :uuidable, uuid: uuid, name: 'Sequencing by colour' } + before { create(:request_type, :uuidable, uuid: uuid, name: 'Sequencing by colour') } describe '#get' do subject(:url) { '/api/1/' + uuid } diff --git a/spec/api/specific_tube_creation_spec.rb b/spec/api/specific_tube_creation_spec.rb index d941f8296d..a60e675209 100644 --- a/spec/api/specific_tube_creation_spec.rb +++ b/spec/api/specific_tube_creation_spec.rb @@ -3,17 +3,17 @@ require 'rails_helper' describe 'TubeCreation endpoints' do - let(:authorised_app) { create :api_application } - let(:user) { create :user } + let(:authorised_app) { create(:api_application) } + let(:user) { create(:user) } describe 'Creating a tube' do let(:endpoint) { '/api/1/specific_tube_creations' } - let(:parent_plate) { create :plate, well_count: 5 } - let!(:stock_plate) { create :full_stock_plate, well_count: parent_plate.wells.count } - let!(:submission) { Submission.create!(user: user) } + let(:parent_plate) { create(:plate, well_count: 5) } + let!(:stock_plate) { create(:full_stock_plate, well_count: parent_plate.wells.count) } + let!(:submission) { Submission.create!(user:) } - let(:child_purpose) { create :tube_purpose } + let(:child_purpose) { create(:tube_purpose) } before do AssetLink.create!(ancestor: stock_plate, descendant: parent_plate) @@ -125,7 +125,7 @@ def construct_expected_response_body(new_tube_creation) } end - let!(:parent_tube) { create :tube } + let!(:parent_tube) { create(:tube) } let(:payload) do { specific_tube_creation: { diff --git a/spec/api/state_change_spec.rb b/spec/api/state_change_spec.rb index 2e21b88ebe..3d11fcee8b 100644 --- a/spec/api/state_change_spec.rb +++ b/spec/api/state_change_spec.rb @@ -8,9 +8,9 @@ include_context 'a limber target plate with submissions' - let(:authorised_app) { create :api_application } - let(:parent_purpose) { create :plate_purpose } - let(:user) { create :user } + let(:authorised_app) { create(:api_application) } + let(:parent_purpose) { create(:plate_purpose) } + let(:user) { create(:user) } shared_examples 'a state_change_endpoint' do let(:response_code) { 201 } diff --git a/spec/api/submission_pool_spec.rb b/spec/api/submission_pool_spec.rb index 9f1c3d7093..ea177cf901 100644 --- a/spec/api/submission_pool_spec.rb +++ b/spec/api/submission_pool_spec.rb @@ -5,14 +5,14 @@ require_relative 'shared_examples' describe '/api/1/plate-uuid/submission_pools' do - let(:authorised_app) { create :api_application } + let(:authorised_app) { create(:api_application) } let(:uuid) { plate.uuid } let(:custom_metadata_uuid) { collection.uuid } let(:purpose_uuid) { '00000000-1111-2222-3333-666666666666' } - let(:submission) { create :submission } - let(:tag2_layout_template) { create :tag2_layout_template } - let(:tag_layout_template) { create :tag_layout_template } - let(:request_type) { create :library_creation_request_type } + let(:submission) { create(:submission) } + let(:tag2_layout_template) { create(:tag2_layout_template) } + let(:tag_layout_template) { create(:tag_layout_template) } + let(:request_type) { create(:library_creation_request_type) } describe '#get' do subject { '/api/1/' + uuid + '/submission_pools' } @@ -20,7 +20,7 @@ let(:response_code) { 200 } context 'a plate without submissions' do - let(:plate) { create :plate } + let(:plate) { create(:plate) } let(:response_body) do "{ \"actions\": { @@ -37,13 +37,13 @@ end context 'a submission and a used tag 2 template' do - let(:plate) { create :input_plate, well_count: 2 } + let(:plate) { create(:input_plate, well_count: 2) } before do plate.wells.each do |well| - create :library_creation_request, asset: well, submission: submission, request_type: request_type + create(:library_creation_request, asset: well, submission: submission, request_type: request_type) end - create :tag2_layout_template_submission, submission: submission, tag2_layout_template: tag2_layout_template + create(:tag2_layout_template_submission, submission:, tag2_layout_template:) end let(:response_body) do @@ -68,15 +68,17 @@ end context 'a submission with canceleld requests' do - let(:plate) { create :input_plate, well_count: 2 } + let(:plate) { create(:input_plate, well_count: 2) } before do plate.wells.each do |well| - create :library_creation_request, - asset: well, - submission: submission, - request_type: request_type, - state: 'cancelled' + create( + :library_creation_request, + asset: well, + submission: submission, + request_type: request_type, + state: 'cancelled' + ) end end @@ -100,13 +102,13 @@ end context 'a submission and a used tag template' do - let(:plate) { create :input_plate, well_count: 2 } + let(:plate) { create(:input_plate, well_count: 2) } before do plate.wells.each do |well| - create :library_creation_request, asset: well, submission: submission, request_type: request_type + create(:library_creation_request, asset: well, submission: submission, request_type: request_type) end - create :tag_layout_template_submission, submission: submission, tag_layout_template: tag_layout_template + create(:tag_layout_template_submission, submission:, tag_layout_template:) end let(:response_body) do @@ -131,15 +133,15 @@ end context 'a multi plate submission' do - let(:plate) { create :input_plate, well_count: 2 } - let(:plate_b) { create :input_plate, well_count: 2 } + let(:plate) { create(:input_plate, well_count: 2) } + let(:plate_b) { create(:input_plate, well_count: 2) } before do plate.wells.each do |well| - create :library_creation_request, asset: well, submission: submission, request_type: request_type + create(:library_creation_request, asset: well, submission: submission, request_type: request_type) end plate_b.wells.each do |well| - create :library_creation_request, asset: well, submission: submission, request_type: request_type + create(:library_creation_request, asset: well, submission: submission, request_type: request_type) end end @@ -164,18 +166,16 @@ context 'a multi plate submission and a used template on children' do let(:plate_b) do - plate = create :input_plate, well_count: 2 + plate = create(:input_plate, well_count: 2) plate.wells.each do |well| - create :library_creation_request, asset: well, submission: submission, request_type: request_type + create(:library_creation_request, asset: well, submission: submission, request_type: request_type) end plate end - let(:plate) { create :target_plate, well_count: 2, parent: plate_b, submission: submission } + let(:plate) { create(:target_plate, well_count: 2, parent: plate_b, submission: submission) } - before do - create :tag2_layout_template_submission, submission: submission, tag2_layout_template: tag2_layout_template - end + before { create(:tag2_layout_template_submission, submission:, tag2_layout_template:) } let(:response_body) do "{ diff --git a/spec/api/tag_layout_template_spec.rb b/spec/api/tag_layout_template_spec.rb index 9ad4d41da1..b0681f8efd 100644 --- a/spec/api/tag_layout_template_spec.rb +++ b/spec/api/tag_layout_template_spec.rb @@ -8,8 +8,8 @@ subject { '/api/1/tag_layout_templates' } - let(:authorised_app) { create :api_application } - let(:user) { create :user } + let(:authorised_app) { create(:api_application) } + let(:user) { create(:user) } describe '#get' do describe 'with valid tag layout template' do @@ -48,7 +48,7 @@ end let(:response_code) { 200 } - let!(:example_template) { create :tag_layout_template, tags: ['', ''] } + let!(:example_template) { create(:tag_layout_template, tags: ['', '']) } let(:example_template_uuid) { example_template.uuid } let(:example_group) { example_template.tag_group } @@ -78,7 +78,7 @@ end let(:response_code) { 200 } - let!(:example_template) { create :tag_layout_template, tags: ['', ''] } + let!(:example_template) { create(:tag_layout_template, tags: ['', '']) } before do example_template.enabled = false @@ -96,7 +96,7 @@ describe '/api/1/template-uuid' do subject { "/api/1/#{example_template.uuid}" } - let(:example_template) { create :entire_plate_tag_layout_template, name: 'Test Example', tags: %w[AAA TTT] } + let(:example_template) { create(:entire_plate_tag_layout_template, name: 'Test Example', tags: %w[AAA TTT]) } let(:example_tag_group) { example_template.tag_group } describe '#get' do @@ -131,7 +131,7 @@ end describe '#post' do - let(:target) { create :plate } + let(:target) { create(:plate) } let(:payload) { "{\"tag_layout\":{ \"plate\": \"#{target.uuid}\", \"user\": \"#{user.uuid}\"}}" } let(:response_body) do diff --git a/spec/api/transfer_request_collection_spec.rb b/spec/api/transfer_request_collection_spec.rb index 699f75d514..5d4f011208 100644 --- a/spec/api/transfer_request_collection_spec.rb +++ b/spec/api/transfer_request_collection_spec.rb @@ -8,12 +8,12 @@ subject { '/api/1/transfer_request_collection' } - let(:authorised_app) { create :api_application } + let(:authorised_app) { create(:api_application) } - let(:asset) { create :tagged_well } - let(:target_asset) { create :empty_library_tube, barcode: 898 } - let(:user) { create :user } - let(:submission) { create :submission } + let(:asset) { create(:tagged_well) } + let(:target_asset) { create(:empty_library_tube, barcode: 898) } + let(:user) { create(:user) } + let(:submission) { create(:submission) } describe '#post' do let(:payload) do diff --git a/spec/api/tube_creation_spec.rb b/spec/api/tube_creation_spec.rb index fd39e68661..a963636c5c 100644 --- a/spec/api/tube_creation_spec.rb +++ b/spec/api/tube_creation_spec.rb @@ -3,17 +3,17 @@ require 'rails_helper' describe 'TubeCreation endpoints' do - let(:authorised_app) { create :api_application } - let(:user) { create :user } + let(:authorised_app) { create(:api_application) } + let(:user) { create(:user) } describe 'Creating a tube' do let(:endpoint) { '/api/1/tube_creations' } - let(:parent_plate) { create :plate, well_count: 5 } - let!(:stock_plate) { create :full_stock_plate, well_count: parent_plate.wells.count } - let!(:submission) { Submission.create!(user: user) } + let(:parent_plate) { create(:plate, well_count: 5) } + let!(:stock_plate) { create(:full_stock_plate, well_count: parent_plate.wells.count) } + let!(:submission) { Submission.create!(user:) } - let(:child_purpose) { create :tube_purpose } + let(:child_purpose) { create(:tube_purpose) } before do AssetLink.create!(ancestor: stock_plate, descendant: parent_plate) diff --git a/spec/api/tube_purpose_spec.rb b/spec/api/tube_purpose_spec.rb index 9b5fe7ba18..777c790e34 100644 --- a/spec/api/tube_purpose_spec.rb +++ b/spec/api/tube_purpose_spec.rb @@ -3,8 +3,8 @@ require 'rails_helper' describe '/api/1/tube/purposes' do - let(:authorised_app) { create :api_application } - let(:parent_purpose) { create :plate_purpose } + let(:authorised_app) { create(:api_application) } + let(:parent_purpose) { create(:plate_purpose) } let(:payload) do '{ diff --git a/spec/api/well_spec.rb b/spec/api/well_spec.rb index 66f8527da7..8664b0fa03 100644 --- a/spec/api/well_spec.rb +++ b/spec/api/well_spec.rb @@ -4,12 +4,12 @@ require 'support/barcode_helper' describe '/api/1/well-uuid' do - let(:authorised_app) { create :api_application } + let(:authorised_app) { create(:api_application) } let(:uuid) { well.uuid } let(:custom_metadata_uuid) { collection.uuid } let(:purpose_uuid) { '00000000-1111-2222-3333-666666666666' } - let(:well) { create :well_with_sample_and_plate } + let(:well) { create(:well_with_sample_and_plate) } let(:sample) { well.samples.first } before { well } diff --git a/spec/api/work_completion_spec.rb b/spec/api/work_completion_spec.rb index ff0ed12b98..6811384bd8 100644 --- a/spec/api/work_completion_spec.rb +++ b/spec/api/work_completion_spec.rb @@ -8,9 +8,9 @@ subject { '/api/1/work_completions' } - let(:authorised_app) { create :api_application } - let(:parent_purpose) { create :plate_purpose } - let(:user) { create :user } + let(:authorised_app) { create(:api_application) } + let(:parent_purpose) { create(:plate_purpose) } + let(:user) { create(:user) } describe '#post' do let(:payload) do diff --git a/spec/bulk_submission_excel/data_worksheet_spec.rb b/spec/bulk_submission_excel/data_worksheet_spec.rb index b5b03206e4..bd22096467 100644 --- a/spec/bulk_submission_excel/data_worksheet_spec.rb +++ b/spec/bulk_submission_excel/data_worksheet_spec.rb @@ -32,8 +32,8 @@ assets: assets, ranges: configuration.ranges.dup, defaults: { - user_login: user_login, - template_name: template_name + user_login:, + template_name: } ) end diff --git a/spec/bulk_submission_excel/download_spec.rb b/spec/bulk_submission_excel/download_spec.rb index 52375e7a63..7c6b84f12d 100644 --- a/spec/bulk_submission_excel/download_spec.rb +++ b/spec/bulk_submission_excel/download_spec.rb @@ -30,7 +30,7 @@ let(:columns) { configuration.columns.all.dup } let(:ranges) { configuration.ranges.dup } let(:assets) { create(:plate_with_untagged_wells).wells } - let(:submission_template) { create :libray_and_sequencing_template } + let(:submission_template) { create(:library_and_sequencing_template) } after { File.delete(test_file) if File.exist?(test_file) } diff --git a/spec/controllers/admin/primer_panels_controller_spec.rb b/spec/controllers/admin/primer_panels_controller_spec.rb index 4e0d508df0..856f29f85f 100644 --- a/spec/controllers/admin/primer_panels_controller_spec.rb +++ b/spec/controllers/admin/primer_panels_controller_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' describe Admin::PrimerPanelsController do - let(:primer_panel) { create :primer_panel } + let(:primer_panel) { create(:primer_panel) } context 'as admin' do before { session[:user] = create :admin } diff --git a/spec/controllers/api/v2/bioscan/export_pool_xp_to_traction_controller_spec.rb b/spec/controllers/api/v2/bioscan/export_pool_xp_to_traction_controller_spec.rb index 2afd17af33..d2254540d4 100644 --- a/spec/controllers/api/v2/bioscan/export_pool_xp_to_traction_controller_spec.rb +++ b/spec/controllers/api/v2/bioscan/export_pool_xp_to_traction_controller_spec.rb @@ -7,8 +7,8 @@ let(:tube_purpose_name) { 'LBSN-9216 Lib PCR Pool XP' } let(:requested_barcode) { tube.human_barcode } - let(:tube_purpose) { create :tube_purpose, name: tube_purpose_name } - let(:tube) { create :multiplexed_library_tube, purpose: tube_purpose } + let(:tube_purpose) { create(:tube_purpose, name: tube_purpose_name) } + let(:tube) { create(:multiplexed_library_tube, purpose: tube_purpose) } let(:params) do { @@ -22,8 +22,8 @@ end before do - create :transfer_request, state: tube_state, target_asset: tube.receptacle - post api_v2_bioscan_export_pool_xp_to_traction_index_path, params: params + create(:transfer_request, state: tube_state, target_asset: tube.receptacle) + post api_v2_bioscan_export_pool_xp_to_traction_index_path, params: end context 'when the tube exists with the correct properties' do diff --git a/spec/controllers/api/v2/heron/plates_controller_spec.rb b/spec/controllers/api/v2/heron/plates_controller_spec.rb index 2298b4f593..ed3b1fe43a 100644 --- a/spec/controllers/api/v2/heron/plates_controller_spec.rb +++ b/spec/controllers/api/v2/heron/plates_controller_spec.rb @@ -7,7 +7,7 @@ include BarcodeHelper let(:stock_plate_purpose) { PlatePurpose.stock_plate_purpose } - let(:study) { create :study, name: 'Study 1' } + let(:study) { create(:study, name: 'Study 1') } before { mock_plate_barcode_service } @@ -41,7 +41,7 @@ end let!(:before_plate_count) { Plate.count } - before { post api_v2_heron_plates_path, params: params } + before { post api_v2_heron_plates_path, params: } it 'creates a new plate successfully' do expect(response).to have_http_status(:created) @@ -56,7 +56,7 @@ end it 'fails if barcode is not unique with the barcode information' do - post api_v2_heron_plates_path, params: params + post(api_v2_heron_plates_path, params:) expect(response).to have_http_status(:unprocessable_entity) json = ActiveSupport::JSON.decode(response.body) expect(json['errors']).to eq(["The barcode '#{barcode}' is already in use."]) diff --git a/spec/controllers/api/v2/heron/tube_racks_controller_spec.rb b/spec/controllers/api/v2/heron/tube_racks_controller_spec.rb index 94e8df454b..eddbec6ce8 100644 --- a/spec/controllers/api/v2/heron/tube_racks_controller_spec.rb +++ b/spec/controllers/api/v2/heron/tube_racks_controller_spec.rb @@ -7,7 +7,7 @@ include BarcodeHelper let!(:purpose_96) { create(:tube_rack_purpose, target_type: 'TubeRack', size: 96) } - let(:study) { create :study, name: 'Study 1' } + let(:study) { create(:study, name: 'Study 1') } before { mock_plate_barcode_service } @@ -43,7 +43,7 @@ let!(:before_tube_rack_count) { TubeRack.count } let!(:before_tube_count) { Tube.count } - before { post api_v2_heron_tube_racks_path, params: params } + before { post api_v2_heron_tube_racks_path, params: } it 'creates a new tube rack successfully' do expect(response).to have_http_status(:created) diff --git a/spec/controllers/bulk_submission_excel/downloads_controller_spec.rb b/spec/controllers/bulk_submission_excel/downloads_controller_spec.rb index 7baac5bead..71eef6edae 100644 --- a/spec/controllers/bulk_submission_excel/downloads_controller_spec.rb +++ b/spec/controllers/bulk_submission_excel/downloads_controller_spec.rb @@ -3,7 +3,7 @@ RSpec.describe BulkSubmissionExcel::DownloadsController, type: :controller do subject(:downloads_controller) { described_class.new } - let(:submission) { create :submission } + let(:submission) { create(:submission) } before do session[:user] = create :admin diff --git a/spec/controllers/driver_files_controller_spec.rb b/spec/controllers/driver_files_controller_spec.rb index 5af26d8562..308234ffb3 100644 --- a/spec/controllers/driver_files_controller_spec.rb +++ b/spec/controllers/driver_files_controller_spec.rb @@ -3,28 +3,30 @@ require 'rails_helper' RSpec.describe DriverFilesController do - let(:current_user) { create :user } + let(:current_user) { create(:user) } describe '#show' do - let(:robot) { create :full_robot, generation_behaviour_value: 'Tecan' } + let(:robot) { create(:full_robot, generation_behaviour_value: 'Tecan') } let(:time) { Time.zone.local(2010, 7, 12, 10, 25, 0) } - let(:source_plate) { create :plate, well_count: 1 } - let(:destination_plate) { create :plate, well_count: 1, well_factory: :picked_well } - let(:pipeline) { create :cherrypick_pipeline } + let(:source_plate) { create(:plate, well_count: 1) } + let(:destination_plate) { create(:plate, well_count: 1, well_factory: :picked_well) } + let(:pipeline) { create(:cherrypick_pipeline) } let(:transfers) { { source_plate.wells[0] => destination_plate.wells.first } } let(:requests) do - create_list :cherrypick_request, - 1, - asset: source_plate.wells.first, - target_asset: destination_plate.wells.first, - request_type: pipeline.request_types.first, - state: 'passed' + create_list( + :cherrypick_request, + 1, + asset: source_plate.wells.first, + target_asset: destination_plate.wells.first, + request_type: pipeline.request_types.first, + state: 'passed' + ) end - let(:batch) { create :batch, requests: requests, pipeline: pipeline, user: current_user } + let(:batch) { create(:batch, requests: requests, pipeline: pipeline, user: current_user) } before do get :show, params: { batch_id: batch.id, robot_id: robot.id, pick_number: 1 }, session: { user: current_user.id } diff --git a/spec/controllers/lab_searches_controller_spec.rb b/spec/controllers/lab_searches_controller_spec.rb index dab4055114..4a10643ecf 100644 --- a/spec/controllers/lab_searches_controller_spec.rb +++ b/spec/controllers/lab_searches_controller_spec.rb @@ -3,14 +3,14 @@ require 'rails_helper' RSpec.describe LabSearchesController do - let(:current_user) { create :user } + let(:current_user) { create(:user) } it_behaves_like 'it requires login' context 'searching (when logged in)' do let!(:asset) { create(:sample_tube, name: 'FindMeAsset') } let!(:other_asset) { create(:sample_tube) } - let!(:batch) { create :batch, user: current_user } + let!(:batch) { create(:batch, user: current_user) } describe '#new' do before { get :new, params: { q: query }, session: { user: current_user.id } } @@ -65,7 +65,7 @@ end context 'with a plate barcode' do - let(:asset) { create :plate } + let(:asset) { create(:plate) } let(:query) { asset.human_barcode } it 'finds the asset' do diff --git a/spec/controllers/labwhere_receptions_controller_spec.rb b/spec/controllers/labwhere_receptions_controller_spec.rb index bde5bc9cb0..e5aad0a045 100644 --- a/spec/controllers/labwhere_receptions_controller_spec.rb +++ b/spec/controllers/labwhere_receptions_controller_spec.rb @@ -4,10 +4,10 @@ describe LabwhereReceptionsController do context 'Sample Reception' do - let(:user) { create :user, barcode: 'ID48601I', swipecard_code: '02face' } - let(:plate) { create :plate } - let(:plate_2) { create :plate } - let(:sample_tube) { create :sample_tube, barcode: 1 } + let(:user) { create(:user, barcode: 'ID48601I', swipecard_code: '02face') } + let(:plate) { create(:plate) } + let(:plate_2) { create(:plate) } + let(:sample_tube) { create(:sample_tube, barcode: 1) } shared_examples 'a reception' do before do diff --git a/spec/controllers/messengers_controller_spec.rb b/spec/controllers/messengers_controller_spec.rb index d5159278dd..478559df71 100644 --- a/spec/controllers/messengers_controller_spec.rb +++ b/spec/controllers/messengers_controller_spec.rb @@ -3,8 +3,8 @@ require 'rails_helper' RSpec.describe MessengersController do - let(:user) { create :user } - let(:messenger) { create :messenger } + let(:user) { create(:user) } + let(:messenger) { create(:messenger) } before { session[:user] = user.id } diff --git a/spec/controllers/npg_actions/assets_controller_spec.rb b/spec/controllers/npg_actions/assets_controller_spec.rb index 4ab7067013..1095892357 100644 --- a/spec/controllers/npg_actions/assets_controller_spec.rb +++ b/spec/controllers/npg_actions/assets_controller_spec.rb @@ -3,35 +3,41 @@ require 'rails_helper' RSpec.describe NpgActions::AssetsController, type: :request do - let(:user) { create :user, password: 'password' } + let(:user) { create(:user, password: 'password') } - let(:lane) { create :lane_with_stock_plate, name: 'NPG_Action_Lane_Test', qc_state: 'passed', external_release: 1 } - let(:study) { create :study } - let(:pipeline) { create :sequencing_pipeline } - let(:batch) { create :sequencing_batch, state: 'started', qc_state: 'qc_manual' } + let(:lane) { create(:lane_with_stock_plate, name: 'NPG_Action_Lane_Test', qc_state: 'passed', external_release: 1) } + let(:study) { create(:study) } + let(:pipeline) { create(:sequencing_pipeline) } + let(:batch) { create(:sequencing_batch, state: 'started', qc_state: 'qc_manual') } let(:valid_seq_request) do - create :sequencing_request_with_assets, - batch: batch, - request_type: batch.pipeline.request_types.first, - study: study, - target_asset: lane, - state: 'passed' + create( + :sequencing_request_with_assets, + batch: batch, + request_type: batch.pipeline.request_types.first, + study: study, + target_asset: lane, + state: 'passed' + ) end let(:cancelled_seq_request) do - create :sequencing_request_with_assets, - batch: batch, - request_type: batch.pipeline.request_types.first, - study: study, - target_asset: lane, - state: 'cancelled' + create( + :sequencing_request_with_assets, + batch: batch, + request_type: batch.pipeline.request_types.first, + study: study, + target_asset: lane, + state: 'cancelled' + ) end let(:failed_seq_request) do - create :sequencing_request_with_assets, - batch: batch, - request_type: batch.pipeline.request_types.first, - study: study, - target_asset: lane, - state: 'failed' + create( + :sequencing_request_with_assets, + batch: batch, + request_type: batch.pipeline.request_types.first, + study: study, + target_asset: lane, + state: 'failed' + ) end before { post '/login', params: { login: user.login, password: 'password' } } diff --git a/spec/controllers/parents_controller_spec.rb b/spec/controllers/parents_controller_spec.rb index b7ac6868c8..2a7544557a 100644 --- a/spec/controllers/parents_controller_spec.rb +++ b/spec/controllers/parents_controller_spec.rb @@ -3,16 +3,16 @@ require 'rails_helper' RSpec.describe ParentsController do - let(:current_user) { create :user } + let(:current_user) { create(:user) } it_behaves_like 'it requires login', 'show', parent: :receptacle describe '#show' do - let(:child) { create :lane } + let(:child) { create(:lane) } let(:parents) { create_list(:library_tube, parent_number).map(&:receptacle) } before do - parents.each { |parent| create :sequencing_request, target_asset: child, asset: parent } + parents.each { |parent| create(:sequencing_request, target_asset: child, asset: parent) } child.reload get :show, params: { receptacle_id: child.id }, session: { user: current_user.id } end diff --git a/spec/controllers/phi_x/spiked_buffers_controller_spec.rb b/spec/controllers/phi_x/spiked_buffers_controller_spec.rb index ba17b3ee01..b805b9903b 100644 --- a/spec/controllers/phi_x/spiked_buffers_controller_spec.rb +++ b/spec/controllers/phi_x/spiked_buffers_controller_spec.rb @@ -4,8 +4,8 @@ RSpec.describe PhiX::SpikedBuffersController, :phi_x do describe 'POST create' do - let(:current_user) { create :user } - let(:library_tube) { create :phi_x_stock_tube, name: 'PhiX Stock' } + let(:current_user) { create(:user) } + let(:library_tube) { create(:phi_x_stock_tube, name: 'PhiX Stock') } before { post :create, params: { phi_x_spiked_buffer: form_parameters }, session: { user: current_user.id } } diff --git a/spec/controllers/phi_x/stocks_controller_spec.rb b/spec/controllers/phi_x/stocks_controller_spec.rb index 912fe76a3e..2531891dd2 100644 --- a/spec/controllers/phi_x/stocks_controller_spec.rb +++ b/spec/controllers/phi_x/stocks_controller_spec.rb @@ -4,8 +4,8 @@ RSpec.describe PhiX::StocksController, :phi_x do describe 'POST create' do - let(:current_user) { create :user } - let(:study) { create :study } + let(:current_user) { create(:user) } + let(:study) { create(:study) } before { post :create, params: { phi_x_stock: form_parameters }, session: { user: current_user.id } } diff --git a/spec/controllers/phi_xes_controller_spec.rb b/spec/controllers/phi_xes_controller_spec.rb index 0e38077378..da8ca5edea 100644 --- a/spec/controllers/phi_xes_controller_spec.rb +++ b/spec/controllers/phi_xes_controller_spec.rb @@ -4,7 +4,7 @@ RSpec.describe PhiXesController, :phi_x do describe 'GET show' do - let(:current_user) { create :user } + let(:current_user) { create(:user) } before { get :show, session: { user: current_user.id } } diff --git a/spec/controllers/receptacles_controller_spec.rb b/spec/controllers/receptacles_controller_spec.rb index e48053fb78..422116877f 100644 --- a/spec/controllers/receptacles_controller_spec.rb +++ b/spec/controllers/receptacles_controller_spec.rb @@ -3,12 +3,12 @@ require 'rails_helper' RSpec.describe ReceptaclesController do - let(:current_user) { create :user } + let(:current_user) { create(:user) } let!(:tube) { create(:sample_tube).receptacle } - let!(:lane) { create :lane } - let!(:well) { create :untagged_well, study: study } - let(:study) { create :study } + let!(:lane) { create(:lane) } + let!(:well) { create(:untagged_well, study:) } + let(:study) { create(:study) } it_behaves_like 'it requires login' diff --git a/spec/controllers/report_fails_controller_spec.rb b/spec/controllers/report_fails_controller_spec.rb index 76d77a6909..868ae152d8 100644 --- a/spec/controllers/report_fails_controller_spec.rb +++ b/spec/controllers/report_fails_controller_spec.rb @@ -4,10 +4,10 @@ describe ReportFailsController do context 'with Report Fails' do - let(:user) { create :user, barcode: 'ID48601I', swipecard_code: '02face' } - let(:plate) { create :plate } - let(:plate_2) { create :plate } - let(:sample_tube) { create :sample_tube, barcode: 1 } + let(:user) { create(:user, barcode: 'ID48601I', swipecard_code: '02face') } + let(:plate) { create(:plate) } + let(:plate_2) { create(:plate) } + let(:sample_tube) { create(:sample_tube, barcode: 1) } shared_examples 'a successful failure event' do before do diff --git a/spec/controllers/robot_verifications_controller_spec.rb b/spec/controllers/robot_verifications_controller_spec.rb index 846451c7af..8e969afba7 100644 --- a/spec/controllers/robot_verifications_controller_spec.rb +++ b/spec/controllers/robot_verifications_controller_spec.rb @@ -3,12 +3,12 @@ require 'rails_helper' RSpec.describe RobotVerificationsController do - let(:user) { create :user, barcode: 'ID41440E', swipecard_code: '1234567' } - let(:batch) { create :batch, barcode: '6262' } + let(:user) { create(:user, barcode: 'ID41440E', swipecard_code: '1234567') } + let(:batch) { create(:batch, barcode: '6262') } let(:robot) do - create :robot_with_verification_behaviour, barcode: '1', number_of_sources: 4, number_of_destinations: 1 + create(:robot_with_verification_behaviour, barcode: '1', number_of_sources: 4, number_of_destinations: 1) end - let(:plate) { create :plate, barcode: 'SQPD-142334' } + let(:plate) { create(:plate, barcode: 'SQPD-142334') } before { session[:user] = user.id } @@ -65,11 +65,11 @@ before do expected_layout[1].each_with_index do |(barcode, _sort_number), index| - source_plate = create :plate, barcode: barcode + source_plate = create(:plate, barcode:) position = Map.for_position_on_plate(index + 1, 96, source_plate.asset_shape).first - well = create :well, map: position, plate: source_plate - target_well = create :well, map: position, plate: plate - well_request = create :request, state: 'passed', asset: well, target_asset: target_well + well = create(:well, map: position, plate: source_plate) + target_well = create(:well, map: position, plate: plate) + well_request = create(:request, state: 'passed', asset: well, target_asset: target_well) batch.requests << well_request end robot.save @@ -239,10 +239,10 @@ end describe '#submission' do - let(:well) { create :well, plate: plate } - let(:well_request) { create :request, state: 'passed' } - let(:source_plate) { create :plate, barcode: 'SQPD-1234' } - let(:target_well) { create :well, plate: source_plate } + let(:well) { create(:well, plate:) } + let(:well_request) { create(:request, state: 'passed') } + let(:source_plate) { create(:plate, barcode: 'SQPD-1234') } + let(:target_well) { create(:well, plate: source_plate) } before do well_request.asset = well diff --git a/spec/controllers/samples_controller_spec.rb b/spec/controllers/samples_controller_spec.rb index b71e8c5bc8..286308f544 100644 --- a/spec/controllers/samples_controller_spec.rb +++ b/spec/controllers/samples_controller_spec.rb @@ -3,8 +3,8 @@ require 'rails_helper' RSpec.describe SamplesController do - let(:sample) { create :sample } - let(:current_user) { create :user } + let(:sample) { create(:sample) } + let(:current_user) { create(:user) } it_behaves_like 'it requires login' @@ -64,10 +64,12 @@ context 'when consent withdrawn starts off true' do let(:sample) do - create :sample, - consent_withdrawn: true, - date_of_consent_withdrawn: Time.zone.today, - user_id_of_consent_withdrawn: current_user.id + create( + :sample, + consent_withdrawn: true, + date_of_consent_withdrawn: Time.zone.today, + user_id_of_consent_withdrawn: current_user.id + ) end context 'when changing withdraw consent' do diff --git a/spec/controllers/searches_controller_spec.rb b/spec/controllers/searches_controller_spec.rb index f4ccaacca0..bad973cf6a 100644 --- a/spec/controllers/searches_controller_spec.rb +++ b/spec/controllers/searches_controller_spec.rb @@ -3,25 +3,25 @@ require 'rails_helper' RSpec.describe SearchesController do - let(:current_user) { create :user } + let(:current_user) { create(:user) } it_behaves_like 'it requires login' context 'searching (when logged in)' do - let!(:study) { create :study, name: 'FindMeStudy' } - let!(:study2) { create :study, name: 'Another study' } - let!(:sample) { create :sample, name: 'FindMeSample' } + let!(:study) { create(:study, name: 'FindMeStudy') } + let!(:study2) { create(:study, name: 'Another study') } + let!(:sample) { create(:sample, name: 'FindMeSample') } let!(:asset) { create(:sample_tube, name: 'FindMeAsset') } let!(:other_asset) { create(:sample_tube) } - let!(:asset_group_to_find) { create :asset_group, name: 'FindMeAssetGroup', study: study } - let!(:asset_group_to_not_find) { create :asset_group, name: 'IgnoreAssetGroup' } + let!(:asset_group_to_find) { create(:asset_group, name: 'FindMeAssetGroup', study: study) } + let!(:asset_group_to_not_find) { create(:asset_group, name: 'IgnoreAssetGroup') } - let!(:submission) { create :submission, name: 'FindMe' } - let!(:ignore_submission) { create :submission, name: 'IgnoreMeSub' } + let!(:submission) { create(:submission, name: 'FindMe') } + let!(:ignore_submission) { create(:submission, name: 'IgnoreMeSub') } - let!(:sample_with_supplier_name) { create :sample, sample_metadata_attributes: { supplier_name: 'FindMe' } } + let!(:sample_with_supplier_name) { create(:sample, sample_metadata_attributes: { supplier_name: 'FindMe' }) } let!(:sample_with_accession_number) do - create :sample, sample_metadata_attributes: { sample_ebi_accession_number: 'FindMe' } + create(:sample, sample_metadata_attributes: { sample_ebi_accession_number: 'FindMe' }) end describe '#index' do diff --git a/spec/controllers/sequenom_qc_plates_controller_spec.rb b/spec/controllers/sequenom_qc_plates_controller_spec.rb index baa03245c6..37d71dab35 100644 --- a/spec/controllers/sequenom_qc_plates_controller_spec.rb +++ b/spec/controllers/sequenom_qc_plates_controller_spec.rb @@ -4,10 +4,10 @@ RSpec.describe SequenomQcPlatesController, :phi_x do describe 'GET index' do - let(:current_user) { create :user } + let(:current_user) { create(:user) } before do - create_list :sequenom_qc_plate, 2 + create_list(:sequenom_qc_plate, 2) get :index, session: { user: current_user.id } end diff --git a/spec/controllers/studies/information_controller_spec.rb b/spec/controllers/studies/information_controller_spec.rb index a6a14d14af..12d45029d4 100644 --- a/spec/controllers/studies/information_controller_spec.rb +++ b/spec/controllers/studies/information_controller_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' RSpec.describe Studies::InformationController do - let(:study) { create :study } + let(:study) { create(:study) } let(:user) { create(:user) } before { session[:user] = user.id } @@ -20,10 +20,10 @@ end describe '#show with requests' do - let(:request_type1) { create :request_type } - let(:request_type2) { create :request_type } - let(:request_type3) { create :request_type } - let(:well) { create :untagged_well, study: study } + let(:request_type1) { create(:request_type) } + let(:request_type2) { create(:request_type) } + let(:request_type3) { create(:request_type) } + let(:well) { create(:untagged_well, study:) } before do request_type3 diff --git a/spec/controllers/studies_controller_spec.rb b/spec/controllers/studies_controller_spec.rb index ed391348d8..81cf178756 100644 --- a/spec/controllers/studies_controller_spec.rb +++ b/spec/controllers/studies_controller_spec.rb @@ -3,9 +3,9 @@ require 'rails_helper' RSpec.describe StudiesController do - let(:data_release_study_type) { create :data_release_study_type, name: 'genomic sequencing' } - let(:reference_genome) { create :reference_genome } - let(:study) { create :study } + let(:data_release_study_type) { create(:data_release_study_type, name: 'genomic sequencing') } + let(:reference_genome) { create(:reference_genome) } + let(:study) { create(:study) } let(:program) { create(:program) } let(:user) { create(:owner) } @@ -45,7 +45,7 @@ describe '#create' do before do @study_count = Study.count - post :create, params: params + post :create, params: end context 'with valid options' do @@ -110,7 +110,7 @@ let!(:study) do # Create a study without poly_metadata options. - post :create, params: params + post(:create, params:) Study.last end @@ -202,7 +202,7 @@ end describe '#grant_role' do - let(:user) { create :admin } + let(:user) { create(:admin) } before do session[:user] = user.id diff --git a/spec/controllers/submissions_controller_spec.rb b/spec/controllers/submissions_controller_spec.rb index 697b26739c..4d15730d21 100644 --- a/spec/controllers/submissions_controller_spec.rb +++ b/spec/controllers/submissions_controller_spec.rb @@ -5,13 +5,13 @@ RSpec.describe SubmissionsController do render_views - let(:request_type) { create :well_request_type } + let(:request_type) { create(:well_request_type) } it_behaves_like 'it requires login' context 'Submissions controller' do before do - @user = create :user + @user = create(:user) @controller = described_class.new @request = ActionController::TestRequest.create(@controller) @@ -24,11 +24,13 @@ @asset_shape = AssetShape.default @asset_size = 96 - @plate = build :plate, barcode: 'SQPD-123456' + @plate = build(:plate, barcode: 'SQPD-123456') %w[A1 A2 A3 B1 B2 B3 C1 C2 C3].each do |location| well = - build :well_with_sample_and_without_plate, - map: Map.find_by(description: location, asset_shape: @asset_shape, asset_size: @asset_size) + build( + :well_with_sample_and_without_plate, + map: Map.find_by(description: location, asset_shape: @asset_shape, asset_size: @asset_size) + ) @plate.wells << well end build( @@ -37,8 +39,8 @@ plate: @plate ) @plate.save - @study = create :study, name: 'A study' - @project = create :project, name: 'A project' + @study = create(:study, name: 'A study') + @project = create(:project, name: 'A project') submission_template_hash = { name: 'Cherrypicking for Pulldown', submission_class_name: 'LinearSubmission', @@ -154,11 +156,13 @@ context 'with a more recent plate' do before do - @new_plate = create :plate, plate_purpose: @plate.purpose + @new_plate = create(:plate, plate_purpose: @plate.purpose) @well = - create :well, - map: Map.find_by(description: 'A1', asset_shape: @asset_shape, asset_size: @asset_size), - plate: @new_plate + create( + :well, + map: Map.find_by(description: 'A1', asset_shape: @asset_shape, asset_size: @asset_size), + plate: @new_plate + ) create(:aliquot, sample: Sample.find_by(name: @samples.first), receptacle: @well) post( :create, @@ -198,11 +202,13 @@ context 'by sample name and working dilution' do before do @order_count = Order.count - @wd_plate = create :working_dilution_plate + @wd_plate = create(:working_dilution_plate) %w[A1 A2 A3 B1 B2 B3 C1 C2 C3].each do |location| well = - create :empty_well, - map: Map.find_by(description: location, asset_shape: @asset_shape, asset_size: @asset_size) + create( + :empty_well, + map: Map.find_by(description: location, asset_shape: @asset_shape, asset_size: @asset_size) + ) well.aliquots.create(sample: @plate.wells.located_at(location).first.aliquots.first.sample) @wd_plate.wells << well end @@ -292,17 +298,19 @@ context 'A submission with clashing orders' do before do @shared_template = 'shared_template' - @sample = create :sample - @asset_a = create :sample_tube, sample: @sample - @asset_b = create :sample_tube, sample: @sample - @secondary_submission = create :submission + @sample = create(:sample) + @asset_a = create(:sample_tube, sample: @sample) + @asset_b = create(:sample_tube, sample: @sample) + @secondary_submission = create(:submission) @secondary_order = - create :order, - assets: [@asset_b.receptacle], - template_name: @shared_template, - submission: @secondary_submission - @submission = create :submission - @order = create :order, assets: [@asset_a.receptacle], template_name: @shared_template, submission: @submission + create( + :order, + assets: [@asset_b.receptacle], + template_name: @shared_template, + submission: @secondary_submission + ) + @submission = create(:submission) + @order = create(:order, assets: [@asset_a.receptacle], template_name: @shared_template, submission: @submission) end it 'warn the user about duplicates' do @@ -318,11 +326,11 @@ context 'A submission with not ready samples' do before do @shared_template = 'shared_template' - sample_manifest = create :tube_sample_manifest_with_samples + sample_manifest = create(:tube_sample_manifest_with_samples) @samples_names = sample_manifest.samples.map(&:name).join(', ') - @submission = create :submission + @submission = create(:submission) @order = - create :order, assets: sample_manifest.labware, template_name: @shared_template, submission: @submission + create(:order, assets: sample_manifest.labware, template_name: @shared_template, submission: @submission) end it 'warn the user about not ready samples' do @@ -337,10 +345,10 @@ context 'A submission without warnings' do before do @shared_template = 'shared_template' - @sample = create :sample - @asset_a = create :sample_tube, sample: @sample - @submission = create :submission - @order = create :order, assets: [@asset_a.receptacle], template_name: @shared_template, submission: @submission + @sample = create(:sample) + @asset_a = create(:sample_tube, sample: @sample) + @submission = create(:submission) + @order = create(:order, assets: [@asset_a.receptacle], template_name: @shared_template, submission: @submission) end it 'not warn the user about duplicates or samples' do diff --git a/spec/controllers/tag_sets_controller_spec.rb b/spec/controllers/tag_sets_controller_spec.rb index 9c9b934bf6..eb0c799752 100644 --- a/spec/controllers/tag_sets_controller_spec.rb +++ b/spec/controllers/tag_sets_controller_spec.rb @@ -3,8 +3,8 @@ require 'rails_helper' RSpec.describe TagSetsController do - let(:current_user) { create :user } - let(:tag_set) { create :tag_set } + let(:current_user) { create(:user) } + let(:tag_set) { create(:tag_set) } it_behaves_like 'it requires login' @@ -21,7 +21,7 @@ end describe '#show' do - let(:tag_set) { create :tag_set } + let(:tag_set) { create(:tag_set) } before { get :show, params: { id: tag_set.id } } diff --git a/spec/controllers/tube_rack_summaries_controller_spec.rb b/spec/controllers/tube_rack_summaries_controller_spec.rb index e4ce67a7bb..31c2d6ba73 100644 --- a/spec/controllers/tube_rack_summaries_controller_spec.rb +++ b/spec/controllers/tube_rack_summaries_controller_spec.rb @@ -3,10 +3,10 @@ require 'rails_helper' RSpec.describe TubeRackSummariesController do - let(:current_user) { create :user } + let(:current_user) { create(:user) } describe '#show' do - let(:tube_rack) { create :tube_rack } + let(:tube_rack) { create(:tube_rack) } before { get :show, params: { id: tube_rack.primary_barcode.barcode }, session: { user: current_user.id } } diff --git a/spec/data/parsers/cardinal_pbmc_count.csv b/spec/data/parsers/pbmc_count.csv similarity index 100% rename from spec/data/parsers/cardinal_pbmc_count.csv rename to spec/data/parsers/pbmc_count.csv diff --git a/spec/data/parsers/cardinal_pbmc_count_blank_rows.csv b/spec/data/parsers/pbmc_count_blank_rows.csv similarity index 100% rename from spec/data/parsers/cardinal_pbmc_count_blank_rows.csv rename to spec/data/parsers/pbmc_count_blank_rows.csv diff --git a/spec/data/parsers/cardinal_pbmc_count_no_cells.csv b/spec/data/parsers/pbmc_count_no_cells.csv similarity index 100% rename from spec/data/parsers/cardinal_pbmc_count_no_cells.csv rename to spec/data/parsers/pbmc_count_no_cells.csv diff --git a/spec/data/submission/1_valid_rows.csv b/spec/data/submission/1_valid_rows.csv new file mode 100644 index 0000000000..4935dcc02d --- /dev/null +++ b/spec/data/submission/1_valid_rows.csv @@ -0,0 +1 @@ +User Login,template name,study name,project name,submission name,asset names,asset group name,read length,fragment size from,fragment size to,library type,comments user,Illumina-A - Cherrypick for pulldown - Pulldown WGS - HiSeq Paired end sequencing,abc123_study,Test project,sub,,assetgroup123,100,,,Standard,hello there \ No newline at end of file diff --git a/features/submission/csv/2_valid_sc_submissions.csv b/spec/data/submission/2_valid_sc_submissions.csv similarity index 100% rename from features/submission/csv/2_valid_sc_submissions.csv rename to spec/data/submission/2_valid_sc_submissions.csv diff --git a/features/submission/csv/pcr_cycles.csv b/spec/data/submission/pcr_cycles.csv similarity index 100% rename from features/submission/csv/pcr_cycles.csv rename to spec/data/submission/pcr_cycles.csv diff --git a/features/submission/csv/primer_panels.csv b/spec/data/submission/primer_panels.csv similarity index 100% rename from features/submission/csv/primer_panels.csv rename to spec/data/submission/primer_panels.csv diff --git a/spec/data/submission/scrna_additional_validations_invalid.csv b/spec/data/submission/scrna_additional_validations_invalid.csv new file mode 100644 index 0000000000..6af3f0c985 --- /dev/null +++ b/spec/data/submission/scrna_additional_validations_invalid.csv @@ -0,0 +1,3 @@ +User Login,template name,study name,project name,submission name,asset names,asset group name,read length,fragment size from,fragment size to,library type,comments,pre-capture plex level,pre-capture group,gigabases expected,scrna core number of samples per pool,scrna core cells per chip well +user,Limber-Htp - scRNA Core cDNA Prep GEM-X 5p,abc123_study,Test project,sub1,,assetgroup123,100,,,Standard,hello there,,,1.35,15, +user,Limber-Htp - scRNA Core cDNA Prep GEM-X 5p,abc123_study,Test project,sub2,,assetgroup123,100,,,Standard,hello there,,,1.35,10, diff --git a/spec/data/submission/scrna_additional_validations_valid.csv b/spec/data/submission/scrna_additional_validations_valid.csv new file mode 100644 index 0000000000..46da271f46 --- /dev/null +++ b/spec/data/submission/scrna_additional_validations_valid.csv @@ -0,0 +1,3 @@ +User Login,template name,study name,project name,submission name,asset names,asset group name,read length,fragment size from,fragment size to,library type,comments,pre-capture plex level,pre-capture group,gigabases expected,scrna core number of samples per pool,scrna core cells per chip well +user,Limber-Htp - scRNA Core cDNA Prep GEM-X 5p,abc123_study,Test project,sub1,,assetgroup123,100,,,Standard,hello there,,,1.35,15, +user,Limber-Htp - scRNA Core cDNA Prep GEM-X 5p,abc123_study,Test project,sub2,,assetgroup123,100,,,Standard,hello there,,,1.35,15, diff --git a/features/submission/csv/template_for_bulk_submission.csv b/spec/data/submission/template_for_bulk_submission.csv similarity index 100% rename from features/submission/csv/template_for_bulk_submission.csv rename to spec/data/submission/template_for_bulk_submission.csv diff --git a/features/submission/csv/with_lowercase_library_type.csv b/spec/data/submission/with_lowercase_library_type.csv similarity index 100% rename from features/submission/csv/with_lowercase_library_type.csv rename to spec/data/submission/with_lowercase_library_type.csv diff --git a/features/submission/csv/with_unknown_library_type.csv b/spec/data/submission/with_unknown_library_type.csv similarity index 100% rename from features/submission/csv/with_unknown_library_type.csv rename to spec/data/submission/with_unknown_library_type.csv diff --git a/spec/factories/accession/tags.rb b/spec/factories/accession/tags.rb index a2b291417c..c8d4de25c2 100644 --- a/spec/factories/accession/tags.rb +++ b/spec/factories/accession/tags.rb @@ -7,7 +7,7 @@ services { %i[SERVICE_1 SERVICE_2] } ebi_name { :ebi_tag_1 } - initialize_with { new(name: name, groups: groups, services: services, ebi_name: ebi_name) } + initialize_with { new(name:, groups:, services:, ebi_name:) } skip_create factory :sample_taxon_id_accession_tag do diff --git a/spec/factories/aliquots.rb b/spec/factories/aliquots.rb index d3b102b6c8..592aaaef1d 100644 --- a/spec/factories/aliquots.rb +++ b/spec/factories/aliquots.rb @@ -27,7 +27,7 @@ end factory :library_aliquot do - library { build :library_tube } + library { build(:library_tube) } library_type { 'Standard' } bait_library primer_panel @@ -41,7 +41,7 @@ end sample { PhiX.sample } - library { build :library_tube } + library { build(:library_tube) } tag { PhiX.find_tag(tag_option, :i7_oligo) } tag2 { PhiX.find_tag(tag_option, :i5_oligo) } study { nil } diff --git a/spec/factories/asset_groups.rb b/spec/factories/asset_groups.rb index 4411d565ea..4dd707122b 100644 --- a/spec/factories/asset_groups.rb +++ b/spec/factories/asset_groups.rb @@ -2,7 +2,7 @@ FactoryBot.define do factory :asset_group do - name { |_a| generate :asset_group_name } + name { |_a| generate(:asset_group_name) } study transient do @@ -11,7 +11,7 @@ asset_attributes { {} } end - assets { create_list asset_type, asset_count, asset_attributes } + assets { create_list(asset_type, asset_count, asset_attributes) } end factory :asset_group_asset do diff --git a/spec/factories/bait_library_layout_factories.rb b/spec/factories/bait_library_layout_factories.rb new file mode 100644 index 0000000000..82041a4f84 --- /dev/null +++ b/spec/factories/bait_library_layout_factories.rb @@ -0,0 +1,9 @@ +# frozen_string_literal: true + +FactoryBot.define do + factory :bait_library_layout do + user + plate + layout { nil } # This is generated after creation. + end +end diff --git a/spec/factories/batch_factories.rb b/spec/factories/batch_factories.rb index b4077ba19f..aef47324ce 100644 --- a/spec/factories/batch_factories.rb +++ b/spec/factories/batch_factories.rb @@ -23,7 +23,7 @@ if evaluator.request_attributes.present? batch.requests = evaluator.request_attributes.map do |request_attribute| - build(evaluator.request_factory, request_attribute.reverse_merge(request_type: request_type)) + build(evaluator.request_factory, request_attribute.reverse_merge(request_type:)) end end end @@ -57,11 +57,13 @@ after(:build) do |batch, evaluator| evaluator.assets.each_with_index.each do |asset, index| - create :pac_bio_sequencing_request, - asset: asset, - target_asset: evaluator.target_plate.wells[index], - request_type: batch.pipeline.request_types.first, - batch: batch + create( + :pac_bio_sequencing_request, + asset: asset, + target_asset: evaluator.target_plate.wells[index], + request_type: batch.pipeline.request_types.first, + batch: batch + ) end end end diff --git a/spec/factories/custom_metadatum_collection_factories.rb b/spec/factories/custom_metadatum_collection_factories.rb index ea75323023..1bb188cc59 100644 --- a/spec/factories/custom_metadatum_collection_factories.rb +++ b/spec/factories/custom_metadatum_collection_factories.rb @@ -9,11 +9,7 @@ transient { metadatum_count { 5 } } after(:create) do |custom_metadatum_collection, evaluator| - create_list( - :custom_metadatum, - evaluator.metadatum_count, - custom_metadatum_collection: custom_metadatum_collection - ) + create_list(:custom_metadatum, evaluator.metadatum_count, custom_metadatum_collection:) end end end diff --git a/spec/factories/lanes.rb b/spec/factories/lanes.rb index b085fca5f9..4669ddcee3 100644 --- a/spec/factories/lanes.rb +++ b/spec/factories/lanes.rb @@ -2,7 +2,7 @@ FactoryBot.define do factory :lane, traits: [:with_sample_builder] do - name { generate :asset_name } + name { generate(:asset_name) } external_release { nil } factory(:empty_lane) diff --git a/spec/factories/lib_pcr_xp_factories.rb b/spec/factories/lib_pcr_xp_factories.rb index 7258eb7307..76d41aebd7 100644 --- a/spec/factories/lib_pcr_xp_factories.rb +++ b/spec/factories/lib_pcr_xp_factories.rb @@ -30,7 +30,7 @@ .map do |map| tube = create(:lib_pool_tube) plate.children << tube - build(:tagged_well, map: map).tap { |well| create(:lib_pcr_xp_request, asset: well, target_asset: tube) } + build(:tagged_well, map:).tap { |well| create(:lib_pcr_xp_request, asset: well, target_asset: tube) } end end end @@ -42,14 +42,14 @@ end factory :lib_pool_tube, class: 'StockMultiplexedLibraryTube' do - name { |_a| FactoryBot.generate :asset_name } + name { |_a| FactoryBot.generate(:asset_name) } purpose factory: %i[illumina_htp_initial_stock_tube_purpose] after(:create) { |tube| create(:transfer_request, target_asset: tube) } end factory :lib_pool_norm_tube, class: 'MultiplexedLibraryTube' do - transient { parent_tube { create :lib_pool_tube } } - name { generate :asset_name } + transient { parent_tube { create(:lib_pool_tube) } } + name { generate(:asset_name) } purpose factory: %i[illumina_htp_mx_tube_purpose] after(:create) { |tube, factory| create(:transfer_request, asset: factory.parent_tube, target_asset: tube) } end diff --git a/spec/factories/phix_factories.rb b/spec/factories/phix_factories.rb index a7ca5df21e..c1db5d0074 100644 --- a/spec/factories/phix_factories.rb +++ b/spec/factories/phix_factories.rb @@ -17,7 +17,7 @@ name { 'PhiX Spiked Buffer' } concentration { '9.2' } parent_barcode { parent.machine_barcode } - parent { create :phi_x_stock_tube } + parent { create(:phi_x_stock_tube) } volume { '10.0' } number { '1' } end diff --git a/spec/factories/pipelines_factories.rb b/spec/factories/pipelines_factories.rb index 546a33f259..41ba15b9cb 100644 --- a/spec/factories/pipelines_factories.rb +++ b/spec/factories/pipelines_factories.rb @@ -11,7 +11,7 @@ end factory :labware do - name { generate :asset_name } + name { generate(:asset_name) } end factory :plate_creator_purpose, class: 'Plate::Creator::PurposeRelationship' do |_t| @@ -20,7 +20,7 @@ end factory :plate_creator, class: 'Plate::Creator' do - name { generate :plate_creator_name } + name { generate(:plate_creator_name) } end factory :control do @@ -48,7 +48,7 @@ end factory :pipeline do - name { generate :pipeline_name } + name { generate(:pipeline_name) } active { true } transient do @@ -77,7 +77,7 @@ factory :cherrypick_pipeline do transient { request_type { build(:cherrypick_request_type) } } - name { generate :pipeline_name } + name { generate(:pipeline_name) } active { true } max_size { 3000 } summary { true } @@ -92,7 +92,7 @@ end factory :fluidigm_pipeline, class: 'CherrypickPipeline' do - name { generate :pipeline_name } + name { generate(:pipeline_name) } active { true } max_size { 192 } sorter { 11 } @@ -107,10 +107,10 @@ end factory :sequencing_pipeline do - name { generate :pipeline_name } + name { generate(:pipeline_name) } active { true } - workflow { build :lab_workflow_for_pipeline } + workflow { build(:lab_workflow_for_pipeline) } # association(:workflow, factory: :lab_workflow_for_pipeline) after(:build) do |pipeline| @@ -128,7 +128,7 @@ per_item: true, descriptor_attributes: [{ kind: 'Text', sorter: 0, name: 'Concentration' }] ) - create(:add_spiked_in_control_task, workflow: workflow) + create(:add_spiked_in_control_task, workflow:) create( :set_descriptors_task, workflow: workflow, @@ -153,12 +153,12 @@ end factory :pac_bio_sequencing_pipeline do - name { FactoryBot.generate :pipeline_name } + name { FactoryBot.generate(:pipeline_name) } active { true } # association(:workflow, factory: :lab_workflow_for_pipeline) control_request_type_id { -1 } - workflow { build :lab_workflow_for_pipeline } + workflow { build(:lab_workflow_for_pipeline) } after(:build) { |pipeline| pipeline.request_types << create(:pac_bio_sequencing_request_type) } end @@ -191,7 +191,7 @@ end factory :workflow, aliases: [:lab_workflow] do - name { FactoryBot.generate :lab_workflow_name } + name { FactoryBot.generate(:lab_workflow_name) } item_limit { 2 } locale { 'Internal' } @@ -200,29 +200,25 @@ end factory :lab_workflow_for_pipeline, class: 'Workflow' do - name { generate :lab_workflow_name } + name { generate(:lab_workflow_name) } item_limit { 2 } locale { 'Internal' } - after(:build) { |workflow| workflow.pipeline = build(:pipeline, workflow: workflow) unless workflow.pipeline } + after(:build) { |workflow| workflow.pipeline = build(:pipeline, workflow:) unless workflow.pipeline } end factory :fluidigm_pipeline_workflow, class: 'Workflow' do - name { generate :lab_workflow_name } + name { generate(:lab_workflow_name) } - after(:build) do |workflow| - workflow.pipeline = build(:fluidigm_pipeline, workflow: workflow) unless workflow.pipeline - end + after(:build) { |workflow| workflow.pipeline = build(:fluidigm_pipeline, workflow:) unless workflow.pipeline } tasks { [build(:fluidigm_template_task, workflow: nil), build(:cherrypick_task, workflow: nil)] } end factory :cherrypick_pipeline_workflow, class: 'Workflow' do - name { generate :lab_workflow_name } + name { generate(:lab_workflow_name) } - after(:build) do |workflow| - workflow.pipeline = build(:cherrypick_pipeline, workflow: workflow) unless workflow.pipeline - end + after(:build) { |workflow| workflow.pipeline = build(:cherrypick_pipeline, workflow:) unless workflow.pipeline } tasks { [build(:plate_template_task, workflow: nil), build(:cherrypick_task, workflow: nil)] } end diff --git a/spec/factories/plate_factories.rb b/spec/factories/plate_factories.rb index 5a59054e1c..a700925935 100644 --- a/spec/factories/plate_factories.rb +++ b/spec/factories/plate_factories.rb @@ -43,7 +43,7 @@ trait :with_submissions do transient do submission_count { 1 } - submissions { create_list :submission, submission_count } + submissions { create_list(:submission, submission_count) } submission_cycle { submissions.cycle } end after(:create) do |plate, evaluator| @@ -61,7 +61,7 @@ transient { barcode { nil } } # May be a nicer way of doing this? - sanger_barcode { barcode.nil? ? build(:plate_barcode) : build(:plate_barcode, barcode: barcode) } + sanger_barcode { barcode.nil? ? build(:plate_barcode) : build(:plate_barcode, barcode:) } end factory :plate, traits: %i[plate_barcode with_wells] do @@ -76,8 +76,8 @@ factory :target_plate do transient do - parent { build :input_plate } - submission { build :submission } + parent { build(:input_plate) } + submission { build(:submission) } end after(:build) do |plate, evaluator| @@ -92,10 +92,12 @@ outer_request = well_hash[well.map_description].requests.detect { |r| r.submission_id == evaluator.submission.id } - create :transfer_request, - asset: well_hash[well.map_description], - target_asset: well, - outer_request: outer_request + create( + :transfer_request, + asset: well_hash[well.map_description], + target_asset: well, + outer_request: outer_request + ) end end end @@ -170,7 +172,7 @@ well_factory { :tagged_well } end plate_purpose { create(:fluidigm_192_purpose) } - barcodes { build_list :fluidigm, 1 } + barcodes { build_list(:fluidigm, 1) } size { 192 } end end @@ -186,7 +188,7 @@ # A plate that has exactly the right number of wells! factory :pooling_plate do - plate_purpose { create :pooling_plate_purpose } + plate_purpose { create(:pooling_plate_purpose) } transient do well_count { 6 } well_factory { :tagged_well } @@ -283,7 +285,7 @@ factory :strip_tube do name { 'Strip_tube' } size { 8 } - plate_purpose { create :strip_tube_purpose } - after(:create) { |st| st.wells = st.maps.map { |map| create(:well, map: map) } } + plate_purpose { create(:strip_tube_purpose) } + after(:create) { |st| st.wells = st.maps.map { |map| create(:well, map:) } } end end diff --git a/spec/factories/poly_metadata_factories.rb b/spec/factories/poly_metadata_factories.rb index 4b37aa5cf7..f5f2e8c3a2 100644 --- a/spec/factories/poly_metadata_factories.rb +++ b/spec/factories/poly_metadata_factories.rb @@ -5,6 +5,6 @@ sequence(:key) { |n| "some_key_#{n}" } sequence(:value) { |n| "some_value_#{n}" } - metadatable { create :request } + metadatable { create(:request) } end end diff --git a/spec/factories/pooled_plate_creation.rb b/spec/factories/pooled_plate_creation.rb new file mode 100644 index 0000000000..b60b41a6d8 --- /dev/null +++ b/spec/factories/pooled_plate_creation.rb @@ -0,0 +1,12 @@ +# frozen_string_literal: true + +FactoryBot.define do + factory :pooled_plate_creation do + # Without this, create_children! tries to go to Baracoda for a barcode. + sanger_barcode { create(:plate_barcode) } + + child_purpose { |target| target.association(:plate_purpose) } + parents { |target| [target.association(:plate), target.association(:tube)] } + user { |target| target.association(:user) } + end +end diff --git a/spec/factories/product_and_catalogue_factories.rb b/spec/factories/product_and_catalogue_factories.rb index 6d3086364e..2a4ea4a484 100644 --- a/spec/factories/product_and_catalogue_factories.rb +++ b/spec/factories/product_and_catalogue_factories.rb @@ -2,7 +2,7 @@ FactoryBot.define do factory :product_catalogue do - name { |_x| FactoryBot.generate :product_catalogue_name } + name { |_x| FactoryBot.generate(:product_catalogue_name) } factory :single_product_catalogue do selection_behaviour { 'SingleProduct' } @@ -14,7 +14,7 @@ end factory :product do - name { FactoryBot.generate :product_name } + name { FactoryBot.generate(:product_name) } deprecated_at { nil } end diff --git a/spec/factories/project_metadata.rb b/spec/factories/project_metadata.rb index 2bc0e7a04b..efb74b059c 100644 --- a/spec/factories/project_metadata.rb +++ b/spec/factories/project_metadata.rb @@ -2,7 +2,7 @@ FactoryBot.define do factory :budget_division do - name { |_a| generate :budget_division_name } + name { |_a| generate(:budget_division_name) } end factory :project_metadata, class: 'Project::Metadata' do diff --git a/spec/factories/projects.rb b/spec/factories/projects.rb index 80588e8298..cf7f42b759 100644 --- a/spec/factories/projects.rb +++ b/spec/factories/projects.rb @@ -2,14 +2,14 @@ FactoryBot.define do factory :project do - name { generate :project_name } + name { generate(:project_name) } enforce_quotas { false } approved { true } state { 'active' } project_metadata factory :project_with_order do - after(:build) { |project| project.orders ||= [create(:order, project: project)] } + after(:build) { |project| project.orders ||= [create(:order, project:)] } end end diff --git a/spec/factories/pulldown_factories.rb b/spec/factories/pulldown_factories.rb index 9bd4bf6a39..4abd989d3e 100644 --- a/spec/factories/pulldown_factories.rb +++ b/spec/factories/pulldown_factories.rb @@ -61,7 +61,7 @@ factory(:plate_creation) do user - barcode { create(:sequencescape22).barcode } + sanger_barcode { create(:sequencescape22) } parent factory: %i[full_plate], well_count: 2 child_purpose factory: %i[plate_purpose] @@ -79,7 +79,7 @@ after(:build) do |tube_creation| mock_request_type = create(:library_creation_request_type) - stock_plate = create :full_stock_plate, well_count: 2 + stock_plate = create(:full_stock_plate, well_count: 2) stock_wells = stock_plate.wells AssetLink.create!(ancestor: stock_plate, descendant: tube_creation.parent) @@ -90,16 +90,16 @@ .in_column_major_order .in_groups_of(tube_creation.parent.wells.size / 2) .each_with_index do |pool, i| - submission = create :submission + submission = create(:submission) pool.each do |well| - create :transfer_request, asset: stock_wells[i], target_asset: well, submission: submission + create(:transfer_request, asset: stock_wells[i], target_asset: well, submission: submission) mock_request_type.create!( asset: stock_wells[i], target_asset: well, submission: submission, request_metadata_attributes: create(:request_metadata_for_library_creation).attributes ) - create :stock_well_link, target_well: well, source_well: stock_wells[i] + create(:stock_well_link, target_well: well, source_well: stock_wells[i]) end end end diff --git a/spec/factories/purpose_factories.rb b/spec/factories/purpose_factories.rb index 8589ff57c6..e61cdba57d 100644 --- a/spec/factories/purpose_factories.rb +++ b/spec/factories/purpose_factories.rb @@ -3,7 +3,7 @@ FactoryBot.define do factory :purpose do prefix { 'DN' } - name { generate :purpose_name } + name { generate(:purpose_name) } target_type { 'Asset' } factory :stock_purpose do @@ -18,22 +18,22 @@ end factory(:purpose_additional_input, class: 'PlatePurpose::AdditionalInput') do - name { generate :purpose_name } + name { generate(:purpose_name) } target_type { 'Plate' } size { '96' } end factory :strip_tube_purpose, class: 'PlatePurpose' do prefix { 'LS' } - name { generate :purpose_name } + name { generate(:purpose_name) } size { '8' } - asset_shape { create :strip_tube_column_shape } + asset_shape { create(:strip_tube_column_shape) } target_type { 'StripTube' } end factory :plate_purpose do prefix { 'DN' } - name { generate :purpose_name } + name { generate(:purpose_name) } size { 96 } barcode_printer_type factory: %i[plate_barcode_printer_type] target_type { 'Plate' } @@ -83,14 +83,14 @@ end factory :working_dilution_plate_purpose, class: 'DilutionPlatePurpose' do - name { generate :purpose_name } + name { generate(:purpose_name) } target_type { 'WorkingDilutionPlate' } prefix { 'WD' } end factory :tube_purpose, class: 'Tube::Purpose' do prefix { 'NT' } - name { generate :purpose_name } + name { generate(:purpose_name) } target_type { 'MultiplexedLibraryTube' } factory :sample_tube_purpose do @@ -118,7 +118,7 @@ factory :std_mx_tube_purpose, class: 'Tube::StandardMx' do prefix { 'NT' } - name { generate :purpose_name } + name { generate(:purpose_name) } target_type { 'MultiplexedLibraryTube' } end @@ -149,7 +149,7 @@ factory :tube_rack_purpose, class: 'TubeRack::Purpose' do target_type { 'TubeRack' } - name { generate :purpose_name } + name { generate(:purpose_name) } size { 96 } factory :tube_rack_purpose_48 do diff --git a/spec/factories/request_factories.rb b/spec/factories/request_factories.rb index 28bef29184..05e2aa6e0d 100644 --- a/spec/factories/request_factories.rb +++ b/spec/factories/request_factories.rb @@ -53,7 +53,7 @@ request_type factory: %i[sequencing_request_type] request_purpose { :standard } sti_type { 'SequencingRequest' } - request_metadata_attributes { attributes_for :request_metadata_for_standard_sequencing_with_read_length } + request_metadata_attributes { attributes_for(:request_metadata_for_standard_sequencing_with_read_length) } factory(:sequencing_request_with_assets) do asset factory: %i[library_tube] @@ -85,18 +85,18 @@ asset factory: %i[well] request_type factory: %i[library_request_type] request_purpose { :standard } - request_metadata_attributes { attributes_for :request_metadata_for_library_manufacture } + request_metadata_attributes { attributes_for(:request_metadata_for_library_manufacture) } factory :gbs_request, class: 'IlluminaHtp::Requests::GbsRequest' do - request_metadata_attributes { attributes_for :request_metadata_for_gbs } + request_metadata_attributes { attributes_for(:request_metadata_for_gbs) } end factory :heron_request, class: 'IlluminaHtp::Requests::HeronRequest' do - request_metadata_attributes { attributes_for :request_metadata_for_heron } + request_metadata_attributes { attributes_for(:request_metadata_for_heron) } end factory :heron_tailed_request, class: 'IlluminaHtp::Requests::HeronTailedRequest' do - request_metadata_attributes { attributes_for :request_metadata_for_heron } + request_metadata_attributes { attributes_for(:request_metadata_for_heron) } end end @@ -126,12 +126,12 @@ end factory :cherrypick_for_fluidigm_request do - transient { target_purpose { create :plate_purpose } } + transient { target_purpose { create(:plate_purpose) } } asset factory: %i[well] target_asset factory: %i[well] request_type factory: %i[cherrypick_request_type] request_purpose { :standard } - request_metadata_attributes { { target_purpose: target_purpose } } + request_metadata_attributes { { target_purpose: } } factory :final_cherrypick_for_fluidigm_request do request_type factory: %i[request_type], key: 'pick_to_fluidigm' diff --git a/spec/factories/request_type_factories.rb b/spec/factories/request_type_factories.rb index 97a40577f9..a50d83c244 100644 --- a/spec/factories/request_type_factories.rb +++ b/spec/factories/request_type_factories.rb @@ -3,13 +3,13 @@ FactoryBot.define do trait :library_request_validators do after(:build) do |request_type| - request_type.library_types_request_types << create(:library_types_request_type, request_type: request_type) - request_type.request_type_validators << create(:library_request_type_validator, request_type: request_type) + request_type.library_types_request_types << create(:library_types_request_type, request_type:) + request_type.request_type_validators << create(:library_request_type_validator, request_type:) end end trait :with_library_types do - transient { library_type { build :library_type } } + transient { library_type { build(:library_type) } } after(:build) do |request_type, evaluator| request_type.library_types_request_types << create( @@ -17,13 +17,13 @@ library_type: evaluator.library_type, request_type: request_type ) - request_type.request_type_validators << create(:library_request_type_validator, request_type: request_type) + request_type.request_type_validators << create(:library_request_type_validator, request_type:) end end factory :request_type do - name { generate :request_type_name } - key { generate :request_type_key } + name { generate(:request_type_name) } + key { generate(:request_type_key) } deprecated { false } asset_type { 'SampleTube' } request_class { Request } @@ -35,6 +35,10 @@ request_class { CustomerRequest } end + factory :pbmc_pooling_customer_request_type do + request_class { PbmcPoolingCustomerRequest } + end + factory :cherrypick_request_type do request_class { CherrypickRequest } asset_type { 'Well' } @@ -141,8 +145,8 @@ for_multiplexing { true } after(:build) do |request_type| - request_type.library_types_request_types << create(:library_types_request_type, request_type: request_type) - request_type.request_type_validators << create(:library_request_type_validator, request_type: request_type) + request_type.library_types_request_types << create(:library_types_request_type, request_type:) + request_type.request_type_validators << create(:library_request_type_validator, request_type:) end end @@ -152,8 +156,8 @@ for_multiplexing { true } after(:build) do |request_type| - request_type.library_types_request_types << create(:library_types_request_type, request_type: request_type) - request_type.request_type_validators << create(:library_request_type_validator, request_type: request_type) + request_type.library_types_request_types << create(:library_types_request_type, request_type:) + request_type.request_type_validators << create(:library_request_type_validator, request_type:) end end diff --git a/spec/factories/robot_factories.rb b/spec/factories/robot_factories.rb index 30b53e1eaa..dca75ce8c1 100644 --- a/spec/factories/robot_factories.rb +++ b/spec/factories/robot_factories.rb @@ -44,12 +44,12 @@ factory :robot_with_verification_behaviour do transient { verification_behaviour_value { 'Tecan' } } - robot_properties { build_list :validation_property, 1, value: verification_behaviour_value } + robot_properties { build_list(:validation_property, 1, value: verification_behaviour_value) } end factory :robot_with_generation_behaviour do transient { generation_behaviour_value { 'Tecan' } } - robot_properties { build_list :generation_property, 1, value: generation_behaviour_value } + robot_properties { build_list(:generation_property, 1, value: generation_behaviour_value) } end factory :full_robot do diff --git a/spec/factories/roles.rb b/spec/factories/roles.rb index ba9ac6f378..681292e83a 100644 --- a/spec/factories/roles.rb +++ b/spec/factories/roles.rb @@ -32,17 +32,17 @@ end trait :with_owner do - transient { owner { build :user } } + transient { owner { build(:user) } } roles { |role| [role.association(:role, name: 'owner', users: [owner])] } end trait :with_manager do - transient { manager { build :user } } + transient { manager { build(:user) } } roles { |role| [role.association(:role, name: 'manager', users: [manager])] } end trait :with_follower do - transient { follower { build :user } } + transient { follower { build(:user) } } roles { |role| [role.association(:role, name: 'follower', users: [follower])] } end end diff --git a/spec/factories/sample_manifest_excel/columns.rb b/spec/factories/sample_manifest_excel/columns.rb index 18f47bea9e..6668de34e5 100644 --- a/spec/factories/sample_manifest_excel/columns.rb +++ b/spec/factories/sample_manifest_excel/columns.rb @@ -7,7 +7,7 @@ heading { "Column #{number}" } value { "Value #{number}" } - initialize_with { new(name: name, heading: heading, number: number, value: value) } + initialize_with { new(name:, heading:, number:, value:) } factory :sanger_sample_id_column do name { :sanger_sample_id } diff --git a/spec/factories/sample_manifest_excel/conditional_formattings.rb b/spec/factories/sample_manifest_excel/conditional_formattings.rb index 9d5664472f..363fe0a48e 100644 --- a/spec/factories/sample_manifest_excel/conditional_formattings.rb +++ b/spec/factories/sample_manifest_excel/conditional_formattings.rb @@ -5,11 +5,11 @@ options { { 'option1' => 'value1', 'option2' => 'value2', 'formula' => 'some_formula' } } style { { bg_color: '82CAFA', type: :dxf } } - initialize_with { new(options: options, style: style) } + initialize_with { new(options:, style:) } factory :conditional_formatting_with_formula, class: 'SequencescapeExcel::ConditionalFormatting' do formula { { type: :len, operator: '>', operand: 10 } } - initialize_with { new(options: options, style: style, formula: formula) } + initialize_with { new(options:, style:, formula:) } end skip_create diff --git a/spec/factories/sample_manifest_excel/ranges.rb b/spec/factories/sample_manifest_excel/ranges.rb index 64c3575c58..c4405f2a21 100644 --- a/spec/factories/sample_manifest_excel/ranges.rb +++ b/spec/factories/sample_manifest_excel/ranges.rb @@ -6,7 +6,7 @@ first_row { 1 } worksheet_name { 'Sheet1' } - initialize_with { new(options: options, first_row: first_row, worksheet_name: worksheet_name) } + initialize_with { new(options:, first_row:, worksheet_name:) } skip_create end diff --git a/spec/factories/sample_manifest_excel/test_download_plates.rb b/spec/factories/sample_manifest_excel/test_download_plates.rb index 83bb6ed682..c2c61923f4 100644 --- a/spec/factories/sample_manifest_excel/test_download_plates.rb +++ b/spec/factories/sample_manifest_excel/test_download_plates.rb @@ -2,7 +2,7 @@ FactoryBot.define do factory :test_download_plates, class: 'SampleManifestExcel::TestDownload' do - columns { build :column_list } + columns { build(:column_list) } validation_errors { [] } num_plates { 2 } num_filled_wells_per_plate { 2 } @@ -34,18 +34,18 @@ initialize_with do new( - data: data, - columns: columns, - validation_errors: validation_errors, - partial: partial, - cgap: cgap, - study: study, - supplier: supplier, - num_plates: num_plates, - num_filled_wells_per_plate: num_filled_wells_per_plate, - num_rows_per_well: num_rows_per_well, - type: type, - manifest_type: manifest_type + data:, + columns:, + validation_errors:, + partial:, + cgap:, + study:, + supplier:, + num_plates:, + num_filled_wells_per_plate:, + num_rows_per_well:, + type:, + manifest_type: ) end diff --git a/spec/factories/sample_manifest_excel/test_download_tubes.rb b/spec/factories/sample_manifest_excel/test_download_tubes.rb index 42f872bdb0..3241bd7f3b 100644 --- a/spec/factories/sample_manifest_excel/test_download_tubes.rb +++ b/spec/factories/sample_manifest_excel/test_download_tubes.rb @@ -37,17 +37,17 @@ initialize_with do new( - data: data, - columns: columns, - validation_errors: validation_errors, - no_of_rows: no_of_rows, - partial: partial, - cgap: cgap, - study: study, - supplier: supplier, - count: count, - type: type, - manifest_type: manifest_type + data:, + columns:, + validation_errors:, + no_of_rows:, + partial:, + cgap:, + study:, + supplier:, + count:, + type:, + manifest_type: ) end diff --git a/spec/factories/sample_manifest_excel/test_download_tubes_in_rack.rb b/spec/factories/sample_manifest_excel/test_download_tubes_in_rack.rb index e4205730a6..a58c2c7411 100644 --- a/spec/factories/sample_manifest_excel/test_download_tubes_in_rack.rb +++ b/spec/factories/sample_manifest_excel/test_download_tubes_in_rack.rb @@ -37,17 +37,17 @@ initialize_with do new( - data: data, - columns: columns, - validation_errors: validation_errors, - no_of_rows: no_of_rows, - partial: partial, - cgap: cgap, - study: study, - supplier: supplier, - count: count, - type: type, - manifest_type: manifest_type + data:, + columns:, + validation_errors:, + no_of_rows:, + partial:, + cgap:, + study:, + supplier:, + count:, + type:, + manifest_type: ) end diff --git a/spec/factories/sample_manifest_excel/validations.rb b/spec/factories/sample_manifest_excel/validations.rb index 05d5d4a144..897433395f 100644 --- a/spec/factories/sample_manifest_excel/validations.rb +++ b/spec/factories/sample_manifest_excel/validations.rb @@ -5,7 +5,7 @@ options { { option1: 'value1', option2: 'value2', type: :none, formula1: 'smth' } } range_name { :some_range } - initialize_with { new(options: options) } + initialize_with { new(options:) } skip_create end diff --git a/spec/factories/sample_manifest_factories.rb b/spec/factories/sample_manifest_factories.rb index 21b2e041f7..3a927f9da2 100644 --- a/spec/factories/sample_manifest_factories.rb +++ b/spec/factories/sample_manifest_factories.rb @@ -17,7 +17,7 @@ num_plates { 1 } num_wells_per_plate { 1 } num_samples_per_well { 1 } - plates { create_list :plate, num_plates, well_factory: :empty_well, well_count: num_wells_per_plate } + plates { create_list(:plate, num_plates, well_factory: :empty_well, well_count: num_wells_per_plate) } end barcodes { plates.map(&:human_barcode) } @@ -49,7 +49,7 @@ tube_factory { :empty_sample_tube } end - labware { create_list tube_factory, tube_count } + labware { create_list(tube_factory, tube_count) } after(:build) do |sample_manifest| sample_manifest.labware.each do |tube| @@ -80,7 +80,7 @@ num_plates { 2 } num_filled_wells_per_plate { 2 } num_rows_per_well { 1 } - plates { create_list :plate, num_plates, well_factory: :empty_well, well_count: num_filled_wells_per_plate } + plates { create_list(:plate, num_plates, well_factory: :empty_well, well_count: num_filled_wells_per_plate) } end barcodes { plates.map(&:human_barcode) } diff --git a/spec/factories/samples.rb b/spec/factories/samples.rb index 128023bbab..6306d25142 100644 --- a/spec/factories/samples.rb +++ b/spec/factories/samples.rb @@ -2,12 +2,12 @@ FactoryBot.define do factory :sample do - name { generate :sample_name } + name { generate(:sample_name) } factory :sample_with_well do sequence(:sanger_sample_id, &:to_s) - after(:build) { |sample, _evaluator| sample.wells = create_list(:well_with_sample_and_plate, 1, sample: sample) } + after(:build) { |sample, _evaluator| sample.wells = create_list(:well_with_sample_and_plate, 1, sample:) } end factory :sample_with_gender do diff --git a/spec/factories/shared_traits.rb b/spec/factories/shared_traits.rb index 7ef04b736b..d793eb0268 100644 --- a/spec/factories/shared_traits.rb +++ b/spec/factories/shared_traits.rb @@ -27,7 +27,7 @@ # Using an after build as I need access to both the transient and the resource. after(:build) do |resource, context| - resource.uuid_object = build :uuid, external_id: context.uuid, resource: resource + resource.uuid_object = build(:uuid, external_id: context.uuid, resource: resource) end after(:create) { |resource, _context| resource.uuid_object.save! } diff --git a/spec/factories/specific_tube_creation.rb b/spec/factories/specific_tube_creation.rb new file mode 100644 index 0000000000..9b84c0daf3 --- /dev/null +++ b/spec/factories/specific_tube_creation.rb @@ -0,0 +1,13 @@ +# frozen_string_literal: true + +FactoryBot.define do + factory(:specific_tube_creation) do + child_purposes { |target| [target.association(:tube_purpose), target.association(:tube_purpose)] } + tube_attributes { [{ name: 'Tube one' }, { name: 'Tube two' }] } + user { |target| target.association(:user) } + + # When giving a tube as a parent, we change the prefix away from NT to avoid clashes with tubes created as children + # by other instances of this model. + parents { |target| [target.association(:plate), target.association(:tube, prefix: 'PT')] } + end +end diff --git a/spec/factories/study_factories.rb b/spec/factories/study_factories.rb index d0368d6240..8ab0fcae97 100644 --- a/spec/factories/study_factories.rb +++ b/spec/factories/study_factories.rb @@ -7,7 +7,7 @@ # required (as the login step does this) but it's here for clarity should that ever change. FactoryBot.define do factory :study do - name { generate :study_name } + name { generate(:study_name) } user blocked { false } state { 'active' } @@ -63,14 +63,14 @@ end factory :study_type do - name { generate :study_type_name } + name { generate(:study_type_name) } end factory :data_release_study_type do - name { generate :data_release_study_type_name } + name { generate(:data_release_study_type_name) } end - factory(:faculty_sponsor) { name { |_a| generate :faculty_sponsor_name } } + factory(:faculty_sponsor) { name { |_a| generate(:faculty_sponsor_name) } } factory :study_for_study_list, parent: :study do transient do @@ -99,7 +99,7 @@ factory(:study_for_study_list_pending_ethical_approval) do name { 'Study: Pending ethical approval' } ethically_approved { false } - study_metadata_attributes { FactoryBot.attributes_for :study_metadata_for_study_list_pending_ethical_approval } + study_metadata_attributes { FactoryBot.attributes_for(:study_metadata_for_study_list_pending_ethical_approval) } end factory(:study_for_study_list_remove_x_and_autosomes) do diff --git a/spec/factories/study_reports.rb b/spec/factories/study_reports.rb index c743e2ffa9..3119d3c615 100644 --- a/spec/factories/study_reports.rb +++ b/spec/factories/study_reports.rb @@ -13,7 +13,7 @@ factory :completed_study_report do report_filename { 'progress_report.csv' } after(:build) do |study_report_file| - create :db_file, owner: study_report_file, data: Tempfile.open('progress_report.csv').read + create(:db_file, owner: study_report_file, data: Tempfile.open('progress_report.csv').read) end end end diff --git a/spec/factories/submission_factories.rb b/spec/factories/submission_factories.rb index 12ae5caa42..dfb79715f1 100644 --- a/spec/factories/submission_factories.rb +++ b/spec/factories/submission_factories.rb @@ -18,29 +18,33 @@ submission_class_name { LinearSubmission.name } sequence(:name) { |i| "Template #{i}" } - submission_parameters { { request_type_ids_list: request_type_ids_list } } + submission_parameters { { request_type_ids_list: } } product_catalogue { |pc| pc.association(:single_product_catalogue) } factory :cherrypick_submission_template do name { 'Cherrypick' } - request_types { create_list :cherrypick_request_type, 1 } + request_types { create_list(:cherrypick_request_type, 1) } end factory :limber_wgs_submission_template do transient { request_types { [create(:library_request_type)] } } end - factory :libray_and_sequencing_template do + factory :library_and_sequencing_template do transient { request_types { [create(:library_request_type), create(:sequencing_request_type)] } } end - factory :heron_libray_and_sequencing_template do + factory :heron_library_and_sequencing_template do transient { request_types { [create(:heron_request_type), create(:sequencing_request_type)] } } end - factory :isc_libray_and_sequencing_template do + factory :isc_library_and_sequencing_template do transient { request_types { [create(:isc_library_request_type), create(:sequencing_request_type)] } } end + + factory :pbmc_pooling_submission_template do + transient { request_types { [create(:pbmc_pooling_customer_request_type)] } } + end end factory :order do @@ -69,7 +73,7 @@ request_types { [create(:request_type).id] } factory :library_order do - assets { create_list :untagged_well, 1 } + assets { create_list(:untagged_well, 1) } request_types { [create(:library_request_type).id] } request_options do { @@ -80,7 +84,7 @@ } end template_name { 'test_template_name' } - order_role { create :order_role } + order_role { create(:order_role) } end end diff --git a/spec/factories/tag2_layout_factories.rb b/spec/factories/tag2_layout_factories.rb index 4a11d2a6fd..f68ec1b60d 100644 --- a/spec/factories/tag2_layout_factories.rb +++ b/spec/factories/tag2_layout_factories.rb @@ -8,9 +8,9 @@ end factory :tag2_layout_template do |_itlt| - transient { oligo { generate :oligo } } + transient { oligo { generate(:oligo) } } sequence(:name) { |n| "Tag 2 layout template #{n}" } - tag { |tag| tag.association :tag, oligo: oligo } + tag { |tag| tag.association :tag, oligo: } end factory :tag2_layout_template_submission, class: 'Tag2Layout::TemplateSubmission' do diff --git a/spec/factories/tube_factories.rb b/spec/factories/tube_factories.rb index 1fdc515d9c..7c2cdd653f 100644 --- a/spec/factories/tube_factories.rb +++ b/spec/factories/tube_factories.rb @@ -10,7 +10,7 @@ trait :tube_barcode do transient do barcode_number { barcode } - barcode { generate :barcode_number } + barcode { generate(:barcode_number) } prefix { 'NT' } end sanger_barcode { { prefix: prefix, number: barcode_number } } @@ -27,17 +27,17 @@ end factory :tube, traits: [:tube_barcode] do - name { generate :asset_name } + name { generate(:asset_name) } purpose factory: %i[tube_purpose] end factory :unbarcoded_tube, class: 'Tube' do - name { generate :asset_name } + name { generate(:asset_name) } purpose factory: %i[tube_purpose] end factory :empty_sample_tube, class: 'SampleTube', traits: [:tube_barcode] do - name { generate :asset_name } + name { generate(:asset_name) } qc_state { '' } purpose factory: %i[sample_tube_purpose] # { Tube::Purpose.standard_sample_tube } end @@ -78,7 +78,7 @@ study { create(:study) } end - name { generate :asset_name } + name { generate(:asset_name) } purpose factory: %i[mx_tube_purpose] after(:build) do |tube, evaluator| unless evaluator.sample_count.zero? @@ -88,12 +88,12 @@ end factory :pulldown_multiplexed_library_tube, traits: [:tube_barcode] do - name { generate :asset_name } + name { generate(:asset_name) } public_name { 'ABC' } end factory :stock_multiplexed_library_tube, traits: [:tube_barcode] do - name { |_a| generate :asset_name } + name { |_a| generate(:asset_name) } purpose { Tube::Purpose.stock_mx_tube } factory :new_stock_multiplexed_library_tube do |_t| @@ -102,14 +102,14 @@ end factory(:empty_library_tube, traits: [:tube_barcode], class: 'LibraryTube') do - name { generate :asset_name } + name { generate(:asset_name) } purpose factory: %i[library_tube_purpose] # { Tube::Purpose.standard_library_tube } transient do sample_count { 0 } samples { create_list(:sample, sample_count) } aliquot_factory { :untagged_aliquot } - study { build :study } + study { build(:study) } end after(:build) do |library_tube, evaluator| @@ -165,9 +165,7 @@ prep_kit_barcode { 999 } smrt_cells_available { 1 } end - pac_bio_library_tube_metadata_attributes do - { prep_kit_barcode: prep_kit_barcode, smrt_cells_available: smrt_cells_available } - end + pac_bio_library_tube_metadata_attributes { { prep_kit_barcode:, smrt_cells_available: } } after(:build) { |t, evaluator| t.receptacle.aliquots << evaluator.aliquot } end @@ -177,17 +175,17 @@ end factory :stock_library_tube do - name { |_a| generate :asset_name } + name { |_a| generate(:asset_name) } purpose { Tube::Purpose.stock_library_tube } end factory :spiked_buffer do transient do tag_option { 'Single' } # The PhiX Tag option to use, eg. Single/Dual - aliquot_attributes { { tag_option: tag_option } } + aliquot_attributes { { tag_option: } } end - name { generate :asset_name } + name { generate(:asset_name) } concentration { 12.0 } volume { 50 } @@ -196,7 +194,7 @@ end factory :spiked_buffer_with_parent do - transient { parent { create :spiked_buffer, :tube_barcode } } + transient { parent { create(:spiked_buffer, :tube_barcode) } } after(:build) { |tube, evaluator| tube.parents << evaluator.parent } end @@ -205,10 +203,10 @@ factory :phi_x_stock_tube, class: 'LibraryTube', traits: [:tube_barcode] do transient do tag_option { 'Single' } # The PhiX Tag option to use, eg. Single/Dual - study { create :study } + study { create(:study) } end - name { generate :asset_name } + name { generate(:asset_name) } concentration { 12.0 } after(:build) do |tube, evaluator| diff --git a/spec/factories/user_factories.rb b/spec/factories/user_factories.rb index 52974073ad..f81caba325 100644 --- a/spec/factories/user_factories.rb +++ b/spec/factories/user_factories.rb @@ -22,7 +22,7 @@ factory :manager do roles { |role| Array(authorizable).map { |auth| role.association(:manager_role, authorizable: auth) } } - transient { authorizable { create :study } } + transient { authorizable { create(:study) } } end factory :owner do diff --git a/spec/factories/user_query_factories.rb b/spec/factories/user_query_factories.rb index e086d6bb5e..c79b174eef 100644 --- a/spec/factories/user_query_factories.rb +++ b/spec/factories/user_query_factories.rb @@ -2,7 +2,7 @@ FactoryBot.define do factory :user_query do - user { create :user, login: 'user_abc', email: 'user_abc@example.com' } + user { create(:user, login: 'user_abc', email: 'user_abc@example.com') } url { 'www.example.com/some_page' } what_was_trying_to_do { 'create' } what_happened { 'it did not work' } diff --git a/spec/factories/well_factories.rb b/spec/factories/well_factories.rb index 3f6f400556..2c8bf62d02 100644 --- a/spec/factories/well_factories.rb +++ b/spec/factories/well_factories.rb @@ -3,9 +3,9 @@ FactoryBot.define do factory :well, aliases: [:empty_well] do transient do - study { build :study } - project { build :project } - sample { build :sample } + study { build(:study) } + project { build(:project) } + sample { build(:sample) } aliquot_options { |_e, well| { study: study, project: project, receptacle: well, sample: sample } } end association(:well_attribute, strategy: :build) @@ -15,7 +15,7 @@ end factory :picked_well do - well_attribute { build :well_attribute, picked_volume: 12 } + well_attribute { build(:well_attribute, picked_volume: 12) } end end @@ -74,7 +74,7 @@ end factory :well_for_qc_report, parent: :well do - samples { [create(:study_sample, study: study).sample] } + samples { [create(:study_sample, study:).sample] } plate { create(:plate) } map { create(:map) } diff --git a/spec/factories/z_tag_qc_factories.rb b/spec/factories/z_tag_qc_factories.rb index 7f93eb31a2..b2b9e98c84 100644 --- a/spec/factories/z_tag_qc_factories.rb +++ b/spec/factories/z_tag_qc_factories.rb @@ -18,12 +18,12 @@ end factory :pending_purpose, parent: :tube_purpose do - name { FactoryBot.generate :purpose_name } + name { FactoryBot.generate(:purpose_name) } default_state { 'pending' } end factory :created_purpose, parent: :tube_purpose do - name { FactoryBot.generate :purpose_name } + name { FactoryBot.generate(:purpose_name) } default_state { 'created' } end @@ -64,12 +64,12 @@ # Incidentally we use attributes_for here as factory_bot instantiates # the object before setting attributes, which messes up the state machine # callbacks. - lot { create :lot } - qcable_creator { create :qcable_creator } + lot { create(:lot) } + qcable_creator { create(:qcable_creator) } factory :qcable_with_asset do state { 'created' } - asset { create :full_plate } + asset { create(:full_plate) } end end diff --git a/spec/features/admin/add_a_primer_panel_spec.rb b/spec/features/admin/add_a_primer_panel_spec.rb index 1cf56fa5c1..aa73044a5a 100644 --- a/spec/features/admin/add_a_primer_panel_spec.rb +++ b/spec/features/admin/add_a_primer_panel_spec.rb @@ -3,8 +3,8 @@ require 'rails_helper' describe 'Primer Panel' do - let(:user) { create :admin, email: 'login@example.com' } - let(:primer_panel) { create :primer_panel, name: 'Primer Panel 1' } + let(:user) { create(:admin, email: 'login@example.com') } + let(:primer_panel) { create(:primer_panel, name: 'Primer Panel 1') } it 'user can add a new primer panel' do login_user user diff --git a/spec/features/admin/add_a_printer_spec.rb b/spec/features/admin/add_a_printer_spec.rb index 8e3e656923..67fc489a4f 100644 --- a/spec/features/admin/add_a_printer_spec.rb +++ b/spec/features/admin/add_a_printer_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' describe 'Add a printer' do - let(:user) { create :admin, email: 'login@example.com' } + let(:user) { create(:admin, email: 'login@example.com') } it 'user can add a new printer' do login_user user diff --git a/spec/features/admin/changing_user_roles_spec.rb b/spec/features/admin/changing_user_roles_spec.rb index 61396f5b63..7296f78e1a 100644 --- a/spec/features/admin/changing_user_roles_spec.rb +++ b/spec/features/admin/changing_user_roles_spec.rb @@ -3,16 +3,16 @@ require 'rails_helper' describe 'Manage users' do - let(:user) { create :admin, email: 'login@example.com' } - let(:test_user) { create :user, login: 'john', first_name: 'John', last_name: 'Smith' } - let(:primer_panel) { create :primer_panel, name: 'Primer Panel 1' } + let(:user) { create(:admin, email: 'login@example.com') } + let(:test_user) { create(:user, login: 'john', first_name: 'John', last_name: 'Smith') } + let(:primer_panel) { create(:primer_panel, name: 'Primer Panel 1') } before do test_user # is_created - create :study, name: 'Study Name', state: 'active' - create :project, name: 'Project Name', state: 'active' - create :role, name: 'lab_manager' - create :role, name: 'manager' + create(:study, name: 'Study Name', state: 'active') + create(:project, name: 'Project Name', state: 'active') + create(:role, name: 'lab_manager') + create(:role, name: 'manager') login_user user click_link 'Admin' expect(page).to have_content('Administration') diff --git a/spec/features/asset_information_spec.rb b/spec/features/asset_information_spec.rb index 68022bf69f..a5758086bd 100644 --- a/spec/features/asset_information_spec.rb +++ b/spec/features/asset_information_spec.rb @@ -9,7 +9,7 @@ # We'll keep the old controller around for a little while to ensure any # bookmarks continue to work. - let(:user) { create :user } + let(:user) { create(:user) } before do expect(Labware).to receive(:find_by).with(id: '1').and_return(labware) @@ -19,7 +19,7 @@ end context 'when the id is unambiguous' do - let(:labware) { create :sample_tube } + let(:labware) { create(:sample_tube) } let(:receptacle) { nil } it 'redirects to the Labware' do @@ -28,7 +28,7 @@ end context 'when the receptacle maps to the labware' do - let(:labware) { create :sample_tube } + let(:labware) { create(:sample_tube) } let(:receptacle) { labware.receptacle } it 'redirects to the Receptacle' do @@ -37,7 +37,7 @@ end context 'when there is some ambiguity' do - let(:labware) { create :sample_tube } + let(:labware) { create(:sample_tube) } let(:receptacle) { create(:sample_tube).receptacle } it 'redirects to the Labware' do diff --git a/spec/features/assets/asset_submission_spec.rb b/spec/features/assets/asset_submission_spec.rb index e7bdfa5247..637555bc85 100644 --- a/spec/features/assets/asset_submission_spec.rb +++ b/spec/features/assets/asset_submission_spec.rb @@ -3,10 +3,10 @@ require 'rails_helper' describe 'Asset submission', :js do - let(:project) { create :project } - let(:study) { create :study } + let(:project) { create(:project) } + let(:study) { create(:study) } let(:request_factory) { :sequencing_request } - let(:asset) { create :library_tube } + let(:asset) { create(:library_tube) } let(:request_types) { create_list(:sequencing_request_type, 2) } let(:original_request_type) { request_types.first } let(:selected_request_type) { original_request_type } @@ -77,7 +77,7 @@ it 'the link is not visible' do login_user user visit labware_path(asset) - expect(page).not_to have_text('Request additional sequencing') + expect(page).to have_no_text('Request additional sequencing') end end @@ -113,7 +113,7 @@ end context 'when an admin' do - let(:user) { create :admin } + let(:user) { create(:admin) } context 'with the original request_type' do it_behaves_like 'it allows additional sequencing' @@ -126,7 +126,7 @@ end context 'when cross study pooled' do - let(:asset) { create :multiplexed_library_tube, aliquots: build_list(:library_aliquot, 2) } + let(:asset) { create(:multiplexed_library_tube, aliquots: build_list(:library_aliquot, 2)) } let(:study) { asset.aliquots.first.study } let(:project) { asset.aliquots.first.project } let!(:original_request) do @@ -139,17 +139,17 @@ end context 'when a regular user' do - let(:user) { create :user } + let(:user) { create(:user) } it_behaves_like 'it forbids additional sequencing' end context 'when study does not have an accession number' do # Create a user that is allowed to request additional sequencing. - let(:user) { create :admin } + let(:user) { create(:admin) } # Create a study that requires accessioning, but does not have an accession number. - let(:study) { create :open_study, enforce_accessioning: true, accession_number: nil } + let(:study) { create(:open_study, enforce_accessioning: true, accession_number: nil) } it_behaves_like 'it shows an error message about study' end diff --git a/spec/features/assets/show_plate_spec.rb b/spec/features/assets/show_plate_spec.rb index 42d59aa867..4ea8073b19 100644 --- a/spec/features/assets/show_plate_spec.rb +++ b/spec/features/assets/show_plate_spec.rb @@ -3,8 +3,8 @@ require 'rails_helper' describe 'Show plate', :js do - let(:plate) { create :plate, well_count: 3 } - let(:user) { create :user } + let(:plate) { create(:plate, well_count: 3) } + let(:user) { create(:user) } before do plate # has been created diff --git a/spec/features/assets/upload_and_retrieve_qc_file_spec.rb b/spec/features/assets/upload_and_retrieve_qc_file_spec.rb index b92884b791..48aef1d9b9 100644 --- a/spec/features/assets/upload_and_retrieve_qc_file_spec.rb +++ b/spec/features/assets/upload_and_retrieve_qc_file_spec.rb @@ -4,8 +4,8 @@ require 'pry' describe 'Asset submission', :js do - let(:plate) { create :plate } - let(:user) { create :user } + let(:plate) { create(:plate) } + let(:user) { create(:user) } it 'upload a qc file' do login_user user diff --git a/spec/features/batches/failing_requests_spec.rb b/spec/features/batches/failing_requests_spec.rb index 135d1cabdf..b2afac1c82 100644 --- a/spec/features/batches/failing_requests_spec.rb +++ b/spec/features/batches/failing_requests_spec.rb @@ -6,14 +6,16 @@ describe 'Batches controller', :js do let(:request_count) { 3 } let(:batch) do - create :cherrypick_batch, - request_count: request_count, - state: 'released', - request_factory: :passed_cherrypick_request + create( + :cherrypick_batch, + request_count: request_count, + state: 'released', + request_factory: :passed_cherrypick_request + ) end - let(:user) { create :admin } + let(:user) { create(:admin) } - before { create :robot } + before { create(:robot) } it 'failing passed cherrypick requests' do request_ids = batch.batch_requests.map(&:request_id) diff --git a/spec/features/batches/sort_requests_spec.rb b/spec/features/batches/sort_requests_spec.rb index 94fd73b0b2..af507a1440 100644 --- a/spec/features/batches/sort_requests_spec.rb +++ b/spec/features/batches/sort_requests_spec.rb @@ -5,9 +5,9 @@ describe 'Batches controller', :js, :warren do let(:request_count) { 3 } - let(:batch) { create :sequencing_batch, request_count: request_count, created_at: 1.day.ago, updated_at: 1.day.ago } - let(:user) { create :admin } - let!(:flowcell_message) { create :flowcell_messenger, target: batch } + let(:batch) { create(:sequencing_batch, request_count: request_count, created_at: 1.day.ago, updated_at: 1.day.ago) } + let(:user) { create(:admin) } + let!(:flowcell_message) { create(:flowcell_messenger, target: batch) } it 'reordering requests' do requests_ids = batch.batch_requests.map(&:request_id) diff --git a/spec/features/contact_us_spec.rb b/spec/features/contact_us_spec.rb index 76f0b31339..c2f94bc049 100644 --- a/spec/features/contact_us_spec.rb +++ b/spec/features/contact_us_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' describe 'Contact us' do - let(:user) { create :user, email: 'login@example.com' } + let(:user) { create(:user, email: 'login@example.com') } it 'user can ask for help' do number_of_mails = ActionMailer::Base.deliveries.count diff --git a/spec/features/creating_a_quad_stamp_spec.rb b/spec/features/creating_a_quad_stamp_spec.rb index d1d05d98ab..3453e191b2 100644 --- a/spec/features/creating_a_quad_stamp_spec.rb +++ b/spec/features/creating_a_quad_stamp_spec.rb @@ -3,13 +3,13 @@ require 'rails_helper' describe 'Creating a quad stamp' do - let(:user) { create :slf_manager, swipecard_code: swipecard } + let(:user) { create(:slf_manager, swipecard_code: swipecard) } let(:swipecard) { '123456' } - let(:quad_1) { create :plate_with_untagged_wells, well_count: 2 } - let(:quad_2) { create :plate_with_untagged_wells, well_count: 2 } - let!(:plate_purpose) { create :plate_purpose, size: 384, stock_plate: true } + let(:quad_1) { create(:plate_with_untagged_wells, well_count: 2) } + let(:quad_2) { create(:plate_with_untagged_wells, well_count: 2) } + let!(:plate_purpose) { create(:plate_purpose, size: 384, stock_plate: true) } let(:new_barcode) { build(:plate_barcode) } - let!(:barcode_printer) { create :barcode_printer } + let!(:barcode_printer) { create(:barcode_printer) } before { allow(PlateBarcode).to receive(:create_barcode).and_return(new_barcode) } diff --git a/spec/features/generate_a_bulk_submission_template_spec.rb b/spec/features/generate_a_bulk_submission_template_spec.rb index 462ceb4b0b..454c4b1ce1 100644 --- a/spec/features/generate_a_bulk_submission_template_spec.rb +++ b/spec/features/generate_a_bulk_submission_template_spec.rb @@ -3,13 +3,13 @@ require 'rails_helper' describe 'Generate a bulk submission spreadsheet', :bulk_submission_excel, :js do - let!(:user) { create :user } + let!(:user) { create(:user) } let!(:plate) { create(:plate_with_untagged_wells, well_count: 30) } # We only use two wells of out partial plate in our submission. However we are generating 13 # to ensure we are only using the specified well. The other two will be ignored. let!(:partial_plate) { create(:plate_with_untagged_wells, well_count: 13) } - let!(:submission_template) { create :libray_and_sequencing_template } + let!(:submission_template) { create(:library_and_sequencing_template) } let(:iso_date) { Time.current.utc.strftime('%Y%m%d') } let(:filename) { "#{plate.human_barcode}_to_#{partial_plate.human_barcode}_#{iso_date}_#{user.login}.xlsx" } @@ -37,8 +37,8 @@ end context 'with a primer panel submission' do - let!(:submission_template) { create :heron_libray_and_sequencing_template } - let!(:primer_panel) { create :primer_panel } + let!(:submission_template) { create(:heron_library_and_sequencing_template) } + let!(:primer_panel) { create(:primer_panel) } it 'populates the primer panel column' do # Regression test for https://github.com/sanger/sequencescape/issues/2582 @@ -58,8 +58,8 @@ end context 'with a bait_library submission' do - let!(:submission_template) { create :isc_libray_and_sequencing_template } - let!(:bait_library) { create :bait_library } + let!(:submission_template) { create(:isc_library_and_sequencing_template) } + let!(:bait_library) { create(:bait_library) } it 'populates the primer panel column' do # Regression test for https://github.com/sanger/sequencescape/issues/2582 diff --git a/spec/features/gpl207_bug_incorrect_submission_id_on_transfer_spec.rb b/spec/features/gpl207_bug_incorrect_submission_id_on_transfer_spec.rb index 05b417e33e..ad739a1e47 100644 --- a/spec/features/gpl207_bug_incorrect_submission_id_on_transfer_spec.rb +++ b/spec/features/gpl207_bug_incorrect_submission_id_on_transfer_spec.rb @@ -47,13 +47,13 @@ def create_cherrypick_requests(plate, target_plate, transfers, submission_id) # These cherrypick requests will create a transfer request between the wells, all the requests belonging to the same submission id.' do - let(:stock_plate_purpose) { create :stock_plate_purpose } + let(:stock_plate_purpose) { create(:stock_plate_purpose) } let(:stock_plate) do - create :plate, :with_wells, sample_count: 9, plate_purpose: stock_plate_purpose, well_factory: :tagged_well + create(:plate, :with_wells, sample_count: 9, plate_purpose: stock_plate_purpose, well_factory: :tagged_well) end - let(:pcr_xp_purpose) { create :plate_purpose, name: 'LB Lib PCR-XP' } - let(:pcr_xp_plate1) { create :plate, :with_wells, sample_count: 9, plate_purpose: pcr_xp_purpose } - let(:pcr_xp_plate2) { create :plate, :with_wells, sample_count: 9, plate_purpose: pcr_xp_purpose } + let(:pcr_xp_purpose) { create(:plate_purpose, name: 'LB Lib PCR-XP') } + let(:pcr_xp_plate1) { create(:plate, :with_wells, sample_count: 9, plate_purpose: pcr_xp_purpose) } + let(:pcr_xp_plate2) { create(:plate, :with_wells, sample_count: 9, plate_purpose: pcr_xp_purpose) } let(:stamp_transfers) do pcr_xp_plate1.wells.each_with_object({}) { |w, hash| hash[w.map_description] = w.map_description } end @@ -78,10 +78,10 @@ def create_cherrypick_requests(plate, target_plate, transfers, submission_id) # context 'when I create a LB Lib Prepool plate and I create 1 Repooling ISC request for each well in the Lib PCR-XP plate' do - let(:prepool_purpose) { create :plate_purpose, name: 'LB Lib Prepool' } - let(:prepool_plate) { create :plate, :with_wells, sample_count: 9, plate_purpose: prepool_purpose } + let(:prepool_purpose) { create(:plate_purpose, name: 'LB Lib Prepool') } + let(:prepool_plate) { create(:plate, :with_wells, sample_count: 9, plate_purpose: prepool_purpose) } - let(:pool_instances1) { create_list :pre_capture_pool, 3 } + let(:pool_instances1) { create_list(:pre_capture_pool, 3) } let(:submission_c) { 4 } let(:submission_d) { 5 } let(:submission_e) { 6 } @@ -113,10 +113,12 @@ def create_cherrypick_requests(plate, target_plate, transfers, submission_id) # it 'will create the transfer requests using the submissions ids from the Repooling requests' do # Now we create the transfer requests that represent the pool from before - create :transfer_between_plates, - transfers: pool_transfer1, - source: pcr_xp_plate1, - destination: prepool_plate + create( + :transfer_between_plates, + transfers: pool_transfer1, + source: pcr_xp_plate1, + destination: prepool_plate + ) # The new transfer requests should have the submission id from the pooling requests (4,5,6), not 1 s_ids = prepool_plate.wells.map(&:transfer_requests_as_target).flatten.map(&:submission_id) @@ -126,7 +128,7 @@ def create_cherrypick_requests(plate, target_plate, transfers, submission_id) # context 'when I create another Repooling ISC and the new pooling has a different transfers definition' do let(:submission_f) { 7 } let(:submission_g) { 8 } - let(:pool_instances2) { create_list :pre_capture_pool, 2 } + let(:pool_instances2) { create_list(:pre_capture_pool, 2) } let(:pool_transfer2) do { 'A1' => ['A1'], @@ -148,10 +150,12 @@ def create_cherrypick_requests(plate, target_plate, transfers, submission_id) # end it 'creates the transfer with the right submission id' do - create :transfer_between_plates, - transfers: pool_transfer2, - source: pcr_xp_plate1, - destination: prepool_plate + create( + :transfer_between_plates, + transfers: pool_transfer2, + source: pcr_xp_plate1, + destination: prepool_plate + ) s_ids = prepool_plate.wells.map(&:transfer_requests_as_target).flatten.map(&:submission_id) expect(s_ids.uniq).to eq([submission_f, submission_g]) @@ -162,7 +166,7 @@ def create_cherrypick_requests(plate, target_plate, transfers, submission_id) # let(:submission_h) { 9 } let(:submission_i) { 10 } let(:submission_j) { 11 } - let(:pool_instances3) { create_list :pre_capture_pool, 3 } + let(:pool_instances3) { create_list(:pre_capture_pool, 3) } let(:pool_transfer3) do { 'A1' => ['A1'], @@ -194,10 +198,12 @@ def create_cherrypick_requests(plate, target_plate, transfers, submission_id) # # There are 2 pools with equal configuration, so it does not know which pooling requests we are # referring to when creating the transfer requests. expect do - create :transfer_between_plates, - transfers: pool_transfer3, - source: pcr_xp_plate1, - destination: prepool_plate + create( + :transfer_between_plates, + transfers: pool_transfer3, + source: pcr_xp_plate1, + destination: prepool_plate + ) end.to raise_error(ActiveRecord::RecordInvalid) end end diff --git a/spec/features/lab_view_spec.rb b/spec/features/lab_view_spec.rb index b2a2c5fb93..801694d74c 100644 --- a/spec/features/lab_view_spec.rb +++ b/spec/features/lab_view_spec.rb @@ -3,8 +3,8 @@ require 'rails_helper' describe 'Lab view', :js do - let(:user) { create :user, email: 'login@example.com' } - let(:library_tube) { create :library_tube } + let(:user) { create(:user, email: 'login@example.com') } + let(:library_tube) { create(:library_tube) } it 'User can update concentrations' do login_user user diff --git a/spec/features/labware/looking_up_labware_history_spec.rb b/spec/features/labware/looking_up_labware_history_spec.rb index 23457c9667..3f5932904c 100644 --- a/spec/features/labware/looking_up_labware_history_spec.rb +++ b/spec/features/labware/looking_up_labware_history_spec.rb @@ -3,16 +3,18 @@ require 'rails_helper' describe 'See labware history' do - let(:user) { create :admin } - let(:tube) { create :tube } + let(:user) { create(:admin) } + let(:tube) { create(:tube) } let!(:asset_audit) do - create :asset_audit, - asset: tube, - created_at: Time.zone.parse('June 16, 2020 15:36'), - metadata: { - 'metadata key' => 'metadata value' - } + create( + :asset_audit, + asset: tube, + created_at: Time.zone.parse('June 16, 2020 15:36'), + metadata: { + 'metadata key' => 'metadata value' + } + ) end it 'displays asset audits', :js do diff --git a/spec/features/labware/retention_instruction_spec.rb b/spec/features/labware/retention_instruction_spec.rb index adcb308edc..c1d322d6eb 100644 --- a/spec/features/labware/retention_instruction_spec.rb +++ b/spec/features/labware/retention_instruction_spec.rb @@ -20,8 +20,8 @@ end context 'when the user is not an admin' do - let(:user) { create :user } - let(:asset) { create :plate_with_3_wells, retention_instruction: :destroy_after_2_years } + let(:user) { create(:user) } + let(:asset) { create(:plate_with_3_wells, retention_instruction: :destroy_after_2_years) } before { visit labware_path(asset) } @@ -39,8 +39,8 @@ end context 'when retention instruction exists' do - let(:user) { create :admin } - let(:asset) { create :plate_with_3_wells, retention_instruction: :destroy_after_2_years } + let(:user) { create(:admin) } + let(:asset) { create(:plate_with_3_wells, retention_instruction: :destroy_after_2_years) } it 'does not display the warning message' do expect(page).to have_no_content 'This labware does not currently have a retention instruction.' @@ -51,8 +51,8 @@ # NB: This scenario will be obsolete (but still valid) after the script in #4095 is run context 'when retention instruction exists in custom_metadata table' do - let(:user) { create :admin } - let(:asset) { create :plate_with_3_wells, retention_instruction: :destroy_after_2_years } + let(:user) { create(:admin) } + let(:asset) { create(:plate_with_3_wells, retention_instruction: :destroy_after_2_years) } before do asset.custom_metadatum_collection = @@ -72,8 +72,8 @@ end context 'when retention instruction does not exist' do - let(:user) { create :admin } - let(:asset) { create :plate_with_3_wells, retention_instruction: nil } + let(:user) { create(:admin) } + let(:asset) { create(:plate_with_3_wells, retention_instruction: nil) } it 'does not have a retention instruction yet' do expect(page).to have_content 'This labware does not currently have a retention instruction.' @@ -83,8 +83,8 @@ end context 'when retention instruction exists for tube' do - let(:user) { create :admin } - let(:asset) { create :tube, retention_instruction: :destroy_after_2_years } + let(:user) { create(:admin) } + let(:asset) { create(:tube, retention_instruction: :destroy_after_2_years) } it 'does not display the warning message' do expect(page).to have_no_content 'This labware does not currently have a retention instruction.' diff --git a/spec/features/labware_information_spec.rb b/spec/features/labware_information_spec.rb index a63ce31282..4135379822 100644 --- a/spec/features/labware_information_spec.rb +++ b/spec/features/labware_information_spec.rb @@ -6,7 +6,7 @@ RSpec.configure { |c| c.include LabWhereClientHelper } describe 'Viewing labware' do - let(:user) { create :user } + let(:user) { create(:user) } shared_examples 'labware' do it 'can be viewed on its show page' do @@ -17,13 +17,13 @@ end context 'with a sample tube' do - let(:labware) { create :sample_tube } + let(:labware) { create(:sample_tube) } it_behaves_like 'labware' end context 'with a library_tube' do - let(:labware) { create :library_tube } + let(:labware) { create(:library_tube) } it_behaves_like 'labware' end @@ -35,7 +35,7 @@ end context 'with a plate' do - let(:labware) { create :plate, well_count: 2 } + let(:labware) { create(:plate, well_count: 2) } context 'when in labwhere' do before do diff --git a/spec/features/labwhere_reception_spec.rb b/spec/features/labwhere_reception_spec.rb index b3bef5eba5..21bd0072df 100644 --- a/spec/features/labwhere_reception_spec.rb +++ b/spec/features/labwhere_reception_spec.rb @@ -3,8 +3,8 @@ require 'rails_helper' describe 'Labwhere reception', :js do - let(:user) { create :user, email: 'login@example.com', swipecard_code: 12_345 } - let(:plate) { create :plate } + let(:user) { create(:user, email: 'login@example.com', swipecard_code: 12_345) } + let(:plate) { create(:plate) } before { configatron.labwhere_api = 'https://labwhere.example.com/api' } # Reset the configatron value after the test to avoid affecting other tests diff --git a/spec/features/patient_consent_withdrawl_spec.rb b/spec/features/patient_consent_withdrawl_spec.rb index ce32397559..027e1eebf6 100644 --- a/spec/features/patient_consent_withdrawl_spec.rb +++ b/spec/features/patient_consent_withdrawl_spec.rb @@ -9,9 +9,9 @@ # Essentially: # - If a patient withdraws consent we need to make sure everyone downstream knows # - We need to stop new orders being made. - let(:user) { create :user, email: 'login@example.com' } - let(:sample) { create :sample_with_gender, consent_withdrawn: consent_withdrawn } - let(:study) { create :study } + let(:user) { create(:user, email: 'login@example.com') } + let(:sample) { create(:sample_with_gender, consent_withdrawn:) } + let(:study) { create(:study) } before { study.samples << sample } @@ -41,8 +41,8 @@ end context 'when batched' do - let(:batch) { create :sequencing_batch, state: 'started' } - let(:lane) { create :lane, samples: [sample] } + let(:batch) { create(:sequencing_batch, state: 'started') } + let(:lane) { create(:lane, samples: [sample]) } before { batch.requests << create(:sequencing_request_with_assets, target_asset: lane) } @@ -55,9 +55,9 @@ context 'an order' do # Lifted straight from the feature test with minimal rspecification # and optimization - let(:submission_template) { create :submission_template, request_type_ids_list: [[create(:request_type).id]] } - let(:sample_tube) { create :sample_tube, sample: sample } - let(:asset_group) { create :asset_group, assets: [sample_tube.receptacle] } + let(:submission_template) { create(:submission_template, request_type_ids_list: [[create(:request_type).id]]) } + let(:sample_tube) { create(:sample_tube, sample:) } + let(:asset_group) { create(:asset_group, assets: [sample_tube.receptacle]) } context 'defined by asset group' do let(:order) do @@ -128,14 +128,14 @@ login_user user visit study_samples_path(study) expect(page).to have_content sample.name - expect(page).not_to have_content "#{sample.name} - Consent withdrawn" - expect(page).not_to have_css('.withdrawn') + expect(page).to have_no_content "#{sample.name} - Consent withdrawn" + expect(page).to have_no_css('.withdrawn') end it 'and a user visit the sample show page' do login_user user visit sample_path(sample) - expect(page).not_to have_content 'Patient consent has been withdrawn for this sample' + expect(page).to have_no_content 'Patient consent has been withdrawn for this sample' end it_behaves_like 'it reports information elsewhere' diff --git a/spec/features/perform_a_tag_substitution_spec.rb b/spec/features/perform_a_tag_substitution_spec.rb index ebe3d92f8e..25489026fb 100644 --- a/spec/features/perform_a_tag_substitution_spec.rb +++ b/spec/features/perform_a_tag_substitution_spec.rb @@ -3,60 +3,72 @@ require 'rails_helper' describe 'Perform a tag substitution', :js do - let(:sample_a) { create :sample } - let(:sample_b) { create :sample } - let(:library_tube_a) { create :library_tube } - let(:library_tube_b) { create :library_tube } - let(:mx_library_tube) { create :multiplexed_library_tube } - let(:library_type) { create :library_type } - let(:used_tag_group) { create :tag_group } - let(:sample_a_orig_tag) { create :tag, tag_group: used_tag_group, map_id: 1 } - let(:sample_a_orig_tag2) { create :tag, tag_group: used_tag_group, map_id: 2 } + let(:sample_a) { create(:sample) } + let(:sample_b) { create(:sample) } + let(:library_tube_a) { create(:library_tube) } + let(:library_tube_b) { create(:library_tube) } + let(:mx_library_tube) { create(:multiplexed_library_tube) } + let(:library_type) { create(:library_type) } + let(:used_tag_group) { create(:tag_group) } + let(:sample_a_orig_tag) { create(:tag, tag_group: used_tag_group, map_id: 1) } + let(:sample_a_orig_tag2) { create(:tag, tag_group: used_tag_group, map_id: 2) } - let(:sample_b_orig_tag) { create :tag, tag_group: used_tag_group, map_id: 3 } - let(:sample_b_orig_tag2) { create :tag, tag_group: used_tag_group, map_id: 4 } + let(:sample_b_orig_tag) { create(:tag, tag_group: used_tag_group, map_id: 3) } + let(:sample_b_orig_tag2) { create(:tag, tag_group: used_tag_group, map_id: 4) } - let!(:lane) { create :lane } + let!(:lane) { create(:lane) } - let(:user) { create :user } + let(:user) { create(:user) } before do - create :aliquot, - sample: sample_a, - tag: sample_a_orig_tag, - tag2: sample_a_orig_tag2, - library: library_tube_a, - receptacle: library_tube_a - create :aliquot, - sample: sample_b, - tag: sample_b_orig_tag, - tag2: sample_b_orig_tag2, - library: library_tube_b, - receptacle: library_tube_b - create :aliquot, - sample: sample_a, - tag: sample_a_orig_tag, - tag2: sample_a_orig_tag2, - library: library_tube_a, - receptacle: mx_library_tube - create :aliquot, - sample: sample_b, - tag: sample_b_orig_tag, - tag2: sample_b_orig_tag2, - library: library_tube_b, - receptacle: mx_library_tube - create :aliquot, - sample: sample_a, - tag: sample_a_orig_tag, - tag2: sample_a_orig_tag2, - library: library_tube_a, - receptacle: lane - create :aliquot, - sample: sample_b, - tag: sample_b_orig_tag, - tag2: sample_b_orig_tag2, - library: library_tube_b, - receptacle: lane + create( + :aliquot, + sample: sample_a, + tag: sample_a_orig_tag, + tag2: sample_a_orig_tag2, + library: library_tube_a, + receptacle: library_tube_a + ) + create( + :aliquot, + sample: sample_b, + tag: sample_b_orig_tag, + tag2: sample_b_orig_tag2, + library: library_tube_b, + receptacle: library_tube_b + ) + create( + :aliquot, + sample: sample_a, + tag: sample_a_orig_tag, + tag2: sample_a_orig_tag2, + library: library_tube_a, + receptacle: mx_library_tube + ) + create( + :aliquot, + sample: sample_b, + tag: sample_b_orig_tag, + tag2: sample_b_orig_tag2, + library: library_tube_b, + receptacle: mx_library_tube + ) + create( + :aliquot, + sample: sample_a, + tag: sample_a_orig_tag, + tag2: sample_a_orig_tag2, + library: library_tube_a, + receptacle: lane + ) + create( + :aliquot, + sample: sample_b, + tag: sample_b_orig_tag, + tag2: sample_b_orig_tag2, + library: library_tube_b, + receptacle: lane + ) end it 'Performing a tag swap' do diff --git a/spec/features/pipelines/cherrypick/cherrypick_for_fluidigm_pipeline_micro_litre_spec.rb b/spec/features/pipelines/cherrypick/cherrypick_for_fluidigm_pipeline_micro_litre_spec.rb index 2251c0a7a3..d9a494b509 100644 --- a/spec/features/pipelines/cherrypick/cherrypick_for_fluidigm_pipeline_micro_litre_spec.rb +++ b/spec/features/pipelines/cherrypick/cherrypick_for_fluidigm_pipeline_micro_litre_spec.rb @@ -4,35 +4,37 @@ require 'pry' describe 'cherrypick for fluidigm pipeline - micro litre', :js do - let(:user) { create :admin } - let(:project) { create :project, name: 'Test project' } - let(:study) { create :study } + let(:user) { create(:admin) } + let(:project) { create(:project, name: 'Test project') } + let(:study) { create(:study) } let(:pipeline_name) { pipeline.name } - let(:pipeline) { create :fluidigm_pipeline } - let(:submission) { create :submission } - let(:plate1) { create :plate_with_untagged_wells, sample_count: 2, barcode: 'SQPD-1' } - let(:plate2) { create :plate_with_untagged_wells, sample_count: 2, barcode: 'SQPD-10' } - let(:plate3) { create :plate_with_untagged_wells, sample_count: 2, barcode: 'SQPD-5' } + let(:pipeline) { create(:fluidigm_pipeline) } + let(:submission) { create(:submission) } + let(:plate1) { create(:plate_with_untagged_wells, sample_count: 2, barcode: 'SQPD-1') } + let(:plate2) { create(:plate_with_untagged_wells, sample_count: 2, barcode: 'SQPD-10') } + let(:plate3) { create(:plate_with_untagged_wells, sample_count: 2, barcode: 'SQPD-5') } let(:plates) { [plate1, plate2, plate3] } - let(:robot) { create :robot, barcode: '444' } - let!(:plate_template) { create :plate_template } + let(:robot) { create(:robot, barcode: '444') } + let!(:plate_template) { create(:plate_template) } let(:request_types) { pipeline.request_types.map(&:key) } before do - target_purpose = create :plate_purpose, name: 'Fluidigm' + target_purpose = create(:plate_purpose, name: 'Fluidigm') assets = plates.each_with_object([]) do |plate, assets| assets.concat(plate.wells) plate.wells.each_with_index { |well, index| well.well_attribute.update!(measured_volume: 30 + (index % 30)) } end assets.each do |asset| - create :cherrypick_for_fluidigm_request, - asset: asset, - request_type: pipeline.request_types.first, - submission: submission, - study: study, - project: project, - target_purpose: target_purpose + create( + :cherrypick_for_fluidigm_request, + asset: asset, + request_type: pipeline.request_types.first, + submission: submission, + study: study, + project: project, + target_purpose: target_purpose + ) end allow(PlateBarcode).to receive(:create_barcode).and_return(build(:plate_barcode, barcode: 'SQPD-2')) diff --git a/spec/features/pipelines/cherrypick/cherrypick_pipeline_spec.rb b/spec/features/pipelines/cherrypick/cherrypick_pipeline_spec.rb index 84f3d6521a..f464a1752c 100644 --- a/spec/features/pipelines/cherrypick/cherrypick_pipeline_spec.rb +++ b/spec/features/pipelines/cherrypick/cherrypick_pipeline_spec.rb @@ -7,10 +7,10 @@ include BarcodeHelper let(:swipecard_code) { '123456' } - let(:user) { create :admin, swipecard_code: swipecard_code } - let(:project) { create :project } - let(:study) { create :study } - let(:pipeline) { create :cherrypick_pipeline } + let(:user) { create(:admin, swipecard_code:) } + let(:project) { create(:project) } + let(:study) { create(:study) } + let(:pipeline) { create(:cherrypick_pipeline) } let(:pipeline_name) { pipeline.name } let(:max_plates) { 17 } let(:robot) do @@ -23,16 +23,16 @@ ) end let(:robot_barcode) { SBCF::SangerBarcode.new(prefix: 'RB', number: robot.barcode).machine_barcode } - let(:submission) { create :submission } - let(:plate_template) { create :plate_template } - let(:plate_type) { create :plate_type, name: 'ABgene_0765', maximum_volume: 800 } + let(:submission) { create(:submission) } + let(:plate_template) { create(:plate_template) } + let(:plate_type) { create(:plate_type, name: 'ABgene_0765', maximum_volume: 800) } let(:_destination_plate_barcode) { build(:plate_barcode) } let(:destination_plate_barcode) { _destination_plate_barcode.barcode } let(:_destination_plate_barcode_2) { build(:plate_barcode) } let(:destination_plate_barcode_2) { _destination_plate_barcode_2.barcode } let(:destination_plate_human_barcode_2) { destination_plate_barcode_2 } let(:destination_plate_human_barcode) { destination_plate_barcode } - let(:target_purpose) { create :plate_purpose } + let(:target_purpose) { create(:plate_purpose) } let(:control_plate) { nil } let(:concentrations_required) { false } let(:custom_destination_type) { nil } @@ -45,12 +45,14 @@ def initialize_plates(plates) plates.each do |plate| plate.wells.each_with_index do |well, index| # create the requests for cherrypicking - create :cherrypick_request, - asset: well, - request_type: pipeline.request_types.first, - submission: submission, - study: study, - project: project + create( + :cherrypick_request, + asset: well, + request_type: pipeline.request_types.first, + submission: submission, + study: study, + project: project + ) # create a concentration value on the wells if required next unless concentrations_required @@ -94,14 +96,14 @@ def initialize_plates(plates) first(:select, 'action_on_requests').select('Create Batch') first(:button, 'Submit').click click_link 'Back to pipeline' - expect(page).not_to have_content(plates[0].human_barcode) + expect(page).to have_no_content(plates[0].human_barcode) end end describe 'where picking by ng/µl for a tecan robot' do let(:concentrations_required) { true } let(:layout_volume_option) { 'Pick by ng/µl' } - let(:custom_destination_type) { create :plate_type, name: 'Custom Type' } + let(:custom_destination_type) { create(:plate_type, name: 'Custom Type') } let(:expected_plates_by_destination_plate) do { destination_plate_human_barcode => { 1 => { sources: [plates[0], plates[1], plates[2]] } } } end @@ -275,7 +277,7 @@ def initialize_plates(plates) describe 'where picking by ng for a tecan robot' do let(:concentrations_required) { true } let(:layout_volume_option) { 'Pick by ng' } - let(:plate_type) { create :plate_type, name: 'ABgene_0800', maximum_volume: 800 } + let(:plate_type) { create(:plate_type, name: 'ABgene_0800', maximum_volume: 800) } let(:expected_plates_by_destination_plate) do { destination_plate_human_barcode => { 1 => { sources: [plates[0], plates[1], plates[2]] } } } end @@ -366,15 +368,15 @@ def initialize_plates(plates) end describe 'where there is a control plate and a single destination' do - let(:plate1) { create :plate_with_untagged_wells, sample_count: 2 } - let(:plate2) { create :plate_with_untagged_wells, sample_count: 2 } - let(:control_plate) { create :control_plate, sample_count: 2 } + let(:plate1) { create(:plate_with_untagged_wells, sample_count: 2) } + let(:plate2) { create(:plate_with_untagged_wells, sample_count: 2) } + let(:control_plate) { create(:control_plate, sample_count: 2) } let(:plates) { [plate1, plate2] } let(:max_plates) { 25 } - let(:robot) { create :hamilton, barcode: '444', max_plates_value: max_plates } + let(:robot) { create(:hamilton, barcode: '444', max_plates_value: max_plates) } let(:concentrations_required) { true } let(:layout_volume_option) { 'Pick by ng/µl' } - let(:custom_destination_type) { create :plate_type, name: 'Custom Type' } + let(:custom_destination_type) { create(:plate_type, name: 'Custom Type') } let(:expected_plates_by_destination_plate) do { destination_plate_human_barcode => { 1 => { sources: [plates[0], plates[1]], control: control_plate } } } end @@ -383,7 +385,7 @@ def initialize_plates(plates) context 'when the number of plates exceeds number of beds (Several runs)' do let(:max_plates) { 2 } - let(:robot) { create :hamilton, barcode: '444', max_plates_value: max_plates } + let(:robot) { create(:hamilton, barcode: '444', max_plates_value: max_plates) } let(:expected_plates_by_destination_plate) do { destination_plate_human_barcode => { @@ -403,16 +405,16 @@ def initialize_plates(plates) end describe 'where there is a control plate and multiple destinations', :js do - let(:plate1) { create :plate_with_untagged_wells, sample_count: 50 } - let(:plate2) { create :plate_with_untagged_wells, sample_count: 50 } - let(:control_plate) { create :control_plate, sample_count: 2 } + let(:plate1) { create(:plate_with_untagged_wells, sample_count: 50) } + let(:plate2) { create(:plate_with_untagged_wells, sample_count: 50) } + let(:control_plate) { create(:control_plate, sample_count: 2) } let(:plates) { [plate1, plate2] } let(:max_plates) { 25 } - let(:robot) { create :hamilton, barcode: '444', max_plates_value: max_plates } + let(:robot) { create(:hamilton, barcode: '444', max_plates_value: max_plates) } let(:concentrations_required) { true } let(:layout_volume_option) { 'Pick by ng/µl' } - let(:custom_destination_type) { create :plate_type, name: 'Custom Type' } + let(:custom_destination_type) { create(:plate_type, name: 'Custom Type') } let(:expected_plates_by_destination_plate) do { destination_plate_human_barcode => { @@ -434,7 +436,7 @@ def initialize_plates(plates) context 'when the number of plates exceeds number of beds (Several runs)' do let(:max_plates) { 2 } - let(:robot) { create :hamilton, barcode: '444', max_plates_value: max_plates } + let(:robot) { create(:hamilton, barcode: '444', max_plates_value: max_plates) } let(:expected_plates_by_destination_plate) do { destination_plate_human_barcode => { diff --git a/spec/features/pipelines/creating_an_empty_batch_spec.rb b/spec/features/pipelines/creating_an_empty_batch_spec.rb index d240403589..582e2764cc 100644 --- a/spec/features/pipelines/creating_an_empty_batch_spec.rb +++ b/spec/features/pipelines/creating_an_empty_batch_spec.rb @@ -3,10 +3,10 @@ require 'rails_helper' describe 'Empty batch creation', :js do - let(:user) { create :user } - let(:pipeline) { create :cherrypick_pipeline } + let(:user) { create(:user) } + let(:pipeline) { create(:cherrypick_pipeline) } let(:pipeline_name) { pipeline.name } - let(:submission) { create :submission } + let(:submission) { create(:submission) } let(:plates) { create_list(:plate_with_untagged_wells_and_custom_name, 1, sample_count: 2) } let(:request_type) { pipeline.request_types.first } @@ -14,7 +14,7 @@ plates.each do |plate| plate.wells.each do |well| # create the requests for cherrypicking - create :cherrypick_request, asset: well, request_type: request_type, submission: submission + create(:cherrypick_request, asset: well, request_type: request_type, submission: submission) end end end diff --git a/spec/features/pipelines/sequencing/following_a_sequencing_pipeline_spec.rb b/spec/features/pipelines/sequencing/following_a_sequencing_pipeline_spec.rb index 26383ba494..99025dcb20 100644 --- a/spec/features/pipelines/sequencing/following_a_sequencing_pipeline_spec.rb +++ b/spec/features/pipelines/sequencing/following_a_sequencing_pipeline_spec.rb @@ -4,18 +4,20 @@ require './spec/features/shared_examples/sequencing' RSpec.describe 'Following a Sequencing Pipeline', :js do - let(:user) { create :user } + let(:user) { create(:user) } let(:pipeline) { create(:sequencing_pipeline, :with_workflow) } - let(:spiked_buffer) { create :spiked_buffer, :tube_barcode } + let(:spiked_buffer) { create(:spiked_buffer, :tube_barcode) } let(:requests) do - asset = create :multiplexed_library_tube, :scanned_into_lab, sample_count: 2 - create_list :sequencing_request_with_assets, - 2, - request_type: pipeline.request_types.first, - asset: asset, - target_asset: nil, - submission: create(:submission) + asset = create(:multiplexed_library_tube, :scanned_into_lab, sample_count: 2) + create_list( + :sequencing_request_with_assets, + 2, + request_type: pipeline.request_types.first, + asset: asset, + target_asset: nil, + submission: create(:submission) + ) end before { requests } @@ -25,14 +27,14 @@ end context 'with one lane of pre-added PhiX' do - let(:existing_spiked_buffer) { create :spiked_buffer, :tube_barcode } + let(:existing_spiked_buffer) { create(:spiked_buffer, :tube_barcode) } let(:with_phi_x) do - tube = create :multiplexed_library_tube, :scanned_into_lab, sample_count: 2 + tube = create(:multiplexed_library_tube, :scanned_into_lab, sample_count: 2) tube.parents << existing_spiked_buffer tube end let(:requests) do - no_phi_x = create :multiplexed_library_tube, :scanned_into_lab, sample_count: 2 + no_phi_x = create(:multiplexed_library_tube, :scanned_into_lab, sample_count: 2) [ create( :sequencing_request_with_assets, @@ -114,31 +116,35 @@ context 'when a batch has been created' do let(:batch) do - create :batch, pipeline: pipeline, requests: pipeline.requests, state: 'released', updated_at: 1.day.ago + create(:batch, pipeline: pipeline, requests: pipeline.requests, state: 'released', updated_at: 1.day.ago) end let!(:flowcell_message) { Messenger.create!(target: batch, template: 'FlowcellIO', root: 'flowcell') } before do batch.requests.each_with_index do |request, i| - create :lab_event, - eventful: request, - batch: batch, - user: user, - description: 'Specify Dilution Volume', - descriptors: { - 'Concentration' => (1.2 + i).to_s - } - create :lab_event, - eventful: request, - batch: batch, - user: user, - description: 'Set descriptors', - descriptors: { - 'Workflow (Standard or Xp)' => 'XP', - 'Lane loading concentration (pM)' => '23', - '+4 field of weirdness' => "Something else #{i}" - } + create( + :lab_event, + eventful: request, + batch: batch, + user: user, + description: 'Specify Dilution Volume', + descriptors: { + 'Concentration' => (1.2 + i).to_s + } + ) + create( + :lab_event, + eventful: request, + batch: batch, + user: user, + description: 'Set descriptors', + descriptors: { + 'Workflow (Standard or Xp)' => 'XP', + 'Lane loading concentration (pM)' => '23', + '+4 field of weirdness' => "Something else #{i}" + } + ) lane = create(:lane) request.update(target_asset: lane) lane.labware.parents << spiked_buffer @@ -248,7 +254,7 @@ login_user(user) visit batch_path(batch) expect(page).to have_content('Fail batch or requests') - expect(page).not_to have_content('Batches can not be failed when pending') + expect(page).to have_no_content('Batches can not be failed when pending') end end end diff --git a/spec/features/pipelines/sequencing/following_a_sequencing_pipeline_with_compound_sample_creation_spec.rb b/spec/features/pipelines/sequencing/following_a_sequencing_pipeline_with_compound_sample_creation_spec.rb index 3a6facd24b..db090a0458 100644 --- a/spec/features/pipelines/sequencing/following_a_sequencing_pipeline_with_compound_sample_creation_spec.rb +++ b/spec/features/pipelines/sequencing/following_a_sequencing_pipeline_with_compound_sample_creation_spec.rb @@ -4,45 +4,51 @@ require './spec/features/shared_examples/sequencing' RSpec.describe 'Following a Sequencing Pipeline', :js do - let(:user) { create :user } - let(:study1) { create :study } - let(:project1) { create :project } + let(:user) { create(:user) } + let(:study1) { create(:study) } + let(:project1) { create(:project) } let(:pipeline) { create(:sequencing_pipeline, :with_workflow) } - let(:spiked_buffer) { create :spiked_buffer, :tube_barcode } - let(:tag) { create :tag, oligo: 'T' } - let(:tag2) { create :tag, oligo: 'C' } + let(:spiked_buffer) { create(:spiked_buffer, :tube_barcode) } + let(:tag) { create(:tag, oligo: 'T') } + let(:tag2) { create(:tag, oligo: 'C') } let(:aliquot1) do - create :aliquot, - tag_id: tag.id, - tag2_id: tag2.id, - tag_depth: 1, - study: study1, - project: project1, - library_type: 'Standard', - library_id: 54 + create( + :aliquot, + tag_id: tag.id, + tag2_id: tag2.id, + tag_depth: 1, + study: study1, + project: project1, + library_type: 'Standard', + library_id: 54 + ) end let(:aliquot2) do - create :aliquot, - tag_id: tag.id, - tag2_id: tag2.id, - tag_depth: 2, - study: study1, - project: project1, - library_type: 'Standard', - library_id: 54 + create( + :aliquot, + tag_id: tag.id, + tag2_id: tag2.id, + tag_depth: 2, + study: study1, + project: project1, + library_type: 'Standard', + library_id: 54 + ) end let(:requests) do - asset = create :multiplexed_library_tube, :scanned_into_lab, sample_count: 2 + asset = create(:multiplexed_library_tube, :scanned_into_lab, sample_count: 2) asset.aliquots = [aliquot1, aliquot2] asset.reload - create_list :sequencing_request_with_assets, - 2, - request_type: pipeline.request_types.first, - asset: asset, - target_asset: nil, - submission: create(:submission) + create_list( + :sequencing_request_with_assets, + 2, + request_type: pipeline.request_types.first, + asset: asset, + target_asset: nil, + submission: create(:submission) + ) end before { requests } diff --git a/spec/features/pipelines/viewing_request_comments_spec.rb b/spec/features/pipelines/viewing_request_comments_spec.rb index 5f6dc0fe6e..bab01eb71a 100644 --- a/spec/features/pipelines/viewing_request_comments_spec.rb +++ b/spec/features/pipelines/viewing_request_comments_spec.rb @@ -3,19 +3,19 @@ require 'rails_helper' describe 'Viewing request comments', :js do - let(:user) { create :user } - let(:pipeline) { create :sequencing_pipeline } + let(:user) { create(:user) } + let(:pipeline) { create(:sequencing_pipeline) } let(:pipeline_name) { pipeline.name } - let(:submission) { create :submission } - let(:tube) { create :multiplexed_library_tube } + let(:submission) { create(:submission) } + let(:tube) { create(:multiplexed_library_tube) } let(:request) do - create :sequencing_request, asset: tube, request_type: pipeline.request_types.first, submission: submission + create(:sequencing_request, asset: tube, request_type: pipeline.request_types.first, submission: submission) end before do - create :comment, commentable: tube, description: 'An excellent tube' - create :comment, commentable: tube.receptacle, description: 'A good receptacle' - create :comment, commentable: request, description: 'A reasonable request' + create(:comment, commentable: tube, description: 'An excellent tube') + create(:comment, commentable: tube.receptacle, description: 'A good receptacle') + create(:comment, commentable: request, description: 'A reasonable request') end it 'returns an error message' do diff --git a/spec/features/plate_qc_display_spec.rb b/spec/features/plate_qc_display_spec.rb index 7b2c84e2b7..569dececa5 100644 --- a/spec/features/plate_qc_display_spec.rb +++ b/spec/features/plate_qc_display_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' describe 'Plate QC display' do - let(:user) { create :user, email: 'login@example.com' } + let(:user) { create(:user, email: 'login@example.com') } describe 'with no QC results' do let!(:plate) { create(:plate, sample_count: 3) } @@ -49,7 +49,7 @@ %w[concentration volume quantity_in_nano_grams loci_passed rin].each do |qc_result| within("##{qc_result}") do plate.wells.each_with_index do |well, index| - expect(page).to have_selector("tr[#{1 + index}]/td[2]", text: well.qc_result_for(qc_result)) + expect(page).to have_css("tr[#{1 + index}]/td[2]", text: well.qc_result_for(qc_result)) end end end diff --git a/spec/features/pooling_spec.rb b/spec/features/pooling_spec.rb index 3b59d8bad4..0afcf2e5d5 100644 --- a/spec/features/pooling_spec.rb +++ b/spec/features/pooling_spec.rb @@ -3,17 +3,17 @@ require 'rails_helper' describe 'Pooling', :js, :poolings do - let(:user) { create :user, email: 'login@example.com' } + let(:user) { create(:user, email: 'login@example.com') } describe 'from page directly' do - let!(:empty_lb_tube1) { create :empty_library_tube, barcode: 1 } - let!(:empty_lb_tube2) { create :empty_library_tube, barcode: 2 } - let!(:untagged_lb_tube1) { create :library_tube, barcode: 3 } + let!(:empty_lb_tube1) { create(:empty_library_tube, barcode: 1) } + let!(:empty_lb_tube2) { create(:empty_library_tube, barcode: 2) } + let!(:untagged_lb_tube1) { create(:library_tube, barcode: 3) } let(:sample1) { untagged_lb_tube1.samples.first } - let!(:untagged_lb_tube2) { create :library_tube, barcode: 4 } + let!(:untagged_lb_tube2) { create(:library_tube, barcode: 4) } let(:sample2) { untagged_lb_tube2.samples.first } - let!(:tagged_lb_tube1) { create :tagged_library_tube, barcode: 5 } - let!(:tagged_lb_tube2) { create :tagged_library_tube, barcode: 6 } + let!(:tagged_lb_tube1) { create(:tagged_library_tube, barcode: 5) } + let!(:tagged_lb_tube2) { create(:tagged_library_tube, barcode: 6) } it 'user can pool from different tubes to stock and standard mx tubes' do login_user user @@ -23,10 +23,10 @@ expect(page).to have_content 'Source assets were not scanned or were not found in Sequencescape' fill_in('asset_scan', with: '1234567890123').send_keys(:return) expect(find('.barcode_list')).to have_content '1234567890123' - fill_in('asset_scan', with: (empty_lb_tube1.ean13_barcode).to_s).send_keys(:return) - fill_in('asset_scan', with: (empty_lb_tube2.ean13_barcode).to_s).send_keys(:return) - fill_in('asset_scan', with: (untagged_lb_tube1.ean13_barcode).to_s).send_keys(:return) - fill_in('asset_scan', with: (untagged_lb_tube2.ean13_barcode).to_s).send_keys(:return) + fill_in('asset_scan', with: empty_lb_tube1.ean13_barcode.to_s).send_keys(:return) + fill_in('asset_scan', with: empty_lb_tube2.ean13_barcode.to_s).send_keys(:return) + fill_in('asset_scan', with: untagged_lb_tube1.ean13_barcode.to_s).send_keys(:return) + fill_in('asset_scan', with: untagged_lb_tube2.ean13_barcode.to_s).send_keys(:return) click_on 'Transfer' expect(page).to have_content 'Source assets with barcode(s) 1234567890123 were not found in Sequencescape' @@ -54,8 +54,8 @@ first('a', text: 'Remove from list').click first('a', text: 'Remove from list').click expect(page).to have_content 'Scanned: 1' - fill_in('asset_scan', with: (tagged_lb_tube1.ean13_barcode).to_s).send_keys(:return) - fill_in('asset_scan', with: (tagged_lb_tube2.ean13_barcode).to_s).send_keys(:return) + fill_in('asset_scan', with: tagged_lb_tube1.ean13_barcode.to_s).send_keys(:return) + fill_in('asset_scan', with: tagged_lb_tube2.ean13_barcode.to_s).send_keys(:return) check 'Create stock multiplexed tube' click_on 'Transfer' expect(page).to have_content 'Samples were transferred successfully' @@ -63,7 +63,7 @@ end describe 'from sample manifest page' do - let!(:sample_manifest) { create :tube_sample_manifest_with_sample_tubes, asset_type: 'library' } + let!(:sample_manifest) { create(:tube_sample_manifest_with_sample_tubes, asset_type: 'library') } before do aliquot = Tube.last.aliquots.first diff --git a/spec/features/receptacle_information_spec.rb b/spec/features/receptacle_information_spec.rb index ba01b62b08..7f03a027a0 100644 --- a/spec/features/receptacle_information_spec.rb +++ b/spec/features/receptacle_information_spec.rb @@ -6,7 +6,7 @@ RSpec.configure { |c| c.include LabWhereClientHelper } describe 'Viewing a receptacle' do - let(:user) { create :user } + let(:user) { create(:user) } shared_examples 'a receptacle' do it 'can be viewed on its show page' do @@ -35,7 +35,7 @@ end context 'with a well' do - let(:receptacle) { create :well } + let(:receptacle) { create(:well) } it_behaves_like 'a receptacle' end diff --git a/spec/features/retrospective_failure_spec.rb b/spec/features/retrospective_failure_spec.rb index 5bedff6b40..93b93ff639 100644 --- a/spec/features/retrospective_failure_spec.rb +++ b/spec/features/retrospective_failure_spec.rb @@ -26,33 +26,33 @@ # minimal consequence, that the additional code complexity outweighs the minor benefits. # The well we'll be failing - let(:target_well) { create :untagged_well } + let(:target_well) { create(:untagged_well) } # The actual request that gets failed. - let(:target_request) { create :transfer_request, target_asset: target_well } + let(:target_request) { create(:transfer_request, target_asset: target_well) } let(:initial_aliquot) { target_well.aliquots.first } - let(:tag) { create :tag } - let(:tag2) { create :tag } + let(:tag) { create(:tag) } + let(:tag2) { create(:tag) } context 'with two descendants and one clash' do - let(:child_well_1) { create :empty_well } + let(:child_well_1) { create(:empty_well) } let(:child_well_2) do - well = create :empty_well + well = create(:empty_well) well.aliquots << create(:tagged_aliquot, receptacle: well, sample: initial_aliquot.sample) well end before do # NOTE: These transfer requests automatically handle the transfer of our aliquot. - create :transfer_request, asset: target_well, target_asset: child_well_1 + create(:transfer_request, asset: target_well, target_asset: child_well_1) # Apply tags to make sure that gets handled correctly child_well_1.aliquots.first.tap do |aliquot| aliquot.tag = tag aliquot.save! end - create :transfer_request, asset: child_well_1, target_asset: child_well_2 + create(:transfer_request, asset: child_well_1, target_asset: child_well_2) # Just double check that the setup has worked as intended expect(child_well_2.aliquots.count).to eq(2) @@ -75,17 +75,17 @@ end context 'with a QcTube descendant' do - let(:child_well_1) { create :empty_well } + let(:child_well_1) { create(:empty_well) } - let(:qc_tube) { create :qc_tube } + let(:qc_tube) { create(:qc_tube) } - let(:lane) { create :lane } + let(:lane) { create(:lane) } before do # NOTE: These transfer requests automatically handle the transfer of our aliquot. - create :transfer_request, asset: target_well, target_asset: child_well_1 - create :transfer_request, asset: target_well, target_asset: qc_tube - create :transfer_request, asset: qc_tube, target_asset: lane + create(:transfer_request, asset: target_well, target_asset: child_well_1) + create(:transfer_request, asset: target_well, target_asset: qc_tube) + create(:transfer_request, asset: qc_tube, target_asset: lane) end it 'fail removed downstream aliquots' do diff --git a/spec/features/sample_logistics/lab/stock_stamping_spec.rb b/spec/features/sample_logistics/lab/stock_stamping_spec.rb index e0d6fdfa40..521bd2dcb1 100644 --- a/spec/features/sample_logistics/lab/stock_stamping_spec.rb +++ b/spec/features/sample_logistics/lab/stock_stamping_spec.rb @@ -3,13 +3,13 @@ require 'rails_helper' describe 'stamping of stock', :js do - let(:user) { create :admin, barcode: 'ID41440E', swipecard_code: '1234567' } - let(:plate) { create :plate_with_3_wells } - let!(:barcode_printer) { create :barcode_printer } + let(:user) { create(:admin, barcode: 'ID41440E', swipecard_code: '1234567') } + let(:plate) { create(:plate_with_3_wells) } + let!(:barcode_printer) { create(:barcode_printer) } before do - create :plate_type, name: 'ABgene_0800', maximum_volume: 180 - create :plate_type, name: 'ABgene_0765', maximum_volume: 800 + create(:plate_type, name: 'ABgene_0800', maximum_volume: 180) + create(:plate_type, name: 'ABgene_0765', maximum_volume: 800) end it 'stamping of stock' do @@ -36,11 +36,11 @@ # rubocop:enable Layout/LineLength expect(page).to have_content 'You can generate the TECAN file and print label now.' - expect(page).not_to have_content('Plates barcodes are not identical') + expect(page).to have_no_content('Plates barcodes are not identical') click_button 'Generate TECAN file' expect(page).to have_content('Stamping of stock') - select((barcode_printer.name).to_s, from: 'barcode_printer_list') + select(barcode_printer.name.to_s, from: 'barcode_printer_list') click_button 'Print label' expect(page).to have_content('Printmybarcode service is down') diff --git a/spec/features/sample_manifests/create_manifest_spec.rb b/spec/features/sample_manifests/create_manifest_spec.rb index 26d47963e8..ad98efd0be 100644 --- a/spec/features/sample_manifests/create_manifest_spec.rb +++ b/spec/features/sample_manifests/create_manifest_spec.rb @@ -10,10 +10,10 @@ def load_manifest_spec end end - let(:user) { create :user } - let!(:printer) { create :barcode_printer } - let!(:supplier) { create :supplier } - let!(:study) { create :study } + let(:user) { create(:user) } + let!(:printer) { create(:barcode_printer) } + let!(:supplier) { create(:supplier) } + let!(:study) { create(:study) } let(:plate_barcode) { build(:plate_barcode) } let(:created_plate) { Plate.with_barcode(plate_barcode.barcode).first } @@ -25,7 +25,7 @@ def load_manifest_spec select(supplier.name, from: 'Supplier') within('#sample_manifest_template') do expect(page).to have_css('option', count: 9) - expect(page).not_to have_css('option', text: 'Default Tube') + expect(page).to have_no_css('option', text: 'Default Tube') end select('Default Plate', from: 'Template') select(printer.name, from: 'Barcode printer') @@ -56,13 +56,13 @@ def load_manifest_spec context 'with a selected purpose' do let(:selected_purpose) { created_purpose } - let!(:created_purpose) { create :plate_purpose, stock_plate: true } + let!(:created_purpose) { create(:plate_purpose, stock_plate: true) } it_behaves_like 'a plate manifest' end context 'without a type specified' do - let!(:created_purpose) { create :plate_purpose, stock_plate: true } + let!(:created_purpose) { create(:plate_purpose, stock_plate: true) } it 'indicate the purpose field is used for plates only' do visit(new_sample_manifest_path) @@ -73,8 +73,8 @@ def load_manifest_spec end context 'with a tube rack manifest' do - let!(:selected_purpose) { create :sample_tube_purpose, name: 'Standard sample' } - let!(:selected_tube_rack_purpose) { create :tube_rack_purpose, name: 'TR Stock 96' } + let!(:selected_purpose) { create(:sample_tube_purpose, name: 'Standard sample') } + let!(:selected_tube_rack_purpose) { create(:tube_rack_purpose, name: 'TR Stock 96') } it 'creating manifests' do click_link('Create manifest for tube racks') @@ -85,7 +85,7 @@ def load_manifest_spec expect(page).to have_css('option', text: 'Default Tube Rack') end select('Default Tube Rack', from: 'Template') - expect(page).not_to have_text('Barcodes') + expect(page).to have_no_text('Barcodes') expect(page).to have_text('Tube racks required') select(selected_purpose.name, from: 'Tube purpose') if selected_purpose expect(page).to have_text('Tube rack purpose') diff --git a/spec/features/sample_manifests/track_sample_manifest_updates_spec.rb b/spec/features/sample_manifests/track_sample_manifest_updates_spec.rb index cdd5fd21ce..2ffbc66c86 100644 --- a/spec/features/sample_manifests/track_sample_manifest_updates_spec.rb +++ b/spec/features/sample_manifests/track_sample_manifest_updates_spec.rb @@ -14,11 +14,11 @@ def load_manifest_spec end end - let(:user) { create :user, login: 'john' } - let(:new_user) { create :user, login: 'jane' } - let!(:printer) { create :barcode_printer } - let!(:supplier) { create :supplier } - let!(:study) { create :study } + let(:user) { create(:user, login: 'john') } + let(:new_user) { create(:user, login: 'jane') } + let!(:printer) { create(:barcode_printer) } + let!(:supplier) { create(:supplier) } + let!(:study) { create(:study) } before do travel_to(Time.zone.local(2010, 7, 12, 10, 25, 0)) @@ -33,7 +33,7 @@ def load_manifest_spec expect(page).to have_content('Create manifest for plates') expect(PlateBarcode).to receive(:create_barcode).and_return(build(:plate_barcode, barcode: 'SQPD-1234567')) - sample_manifest = create :sample_manifest, study: study, supplier: supplier, user: user + sample_manifest = create(:sample_manifest, study:, supplier:, user:) sample_manifest.generate expect(BroadcastEvent.count).to eq broadcast_events_count + 1 diff --git a/spec/features/sample_manifests/uploader_for_manifests_with_tag_sequences_spec.rb b/spec/features/sample_manifests/uploader_for_manifests_with_tag_sequences_spec.rb index 9e21150201..ce916986ac 100644 --- a/spec/features/sample_manifests/uploader_for_manifests_with_tag_sequences_spec.rb +++ b/spec/features/sample_manifests/uploader_for_manifests_with_tag_sequences_spec.rb @@ -19,7 +19,7 @@ after(:all) { SampleManifestExcel.reset! } context 'library tube sample manifest with tag sequences' do - let!(:user) { create :admin } + let!(:user) { create(:admin) } let(:columns) { SampleManifestExcel.configuration.columns.tube_library_with_tag_sequences.dup } let(:test_file) { 'test_file.xlsx' } @@ -30,7 +30,7 @@ context 'valid' do context 'standard' do - let(:download) { build(:test_download_tubes, columns: columns) } + let(:download) { build(:test_download_tubes, columns:) } it 'upload' do login_user(user) @@ -78,7 +78,7 @@ end context 'cgap foreign barcodes' do - let(:download) { build(:test_download_tubes_cgap, columns: columns) } + let(:download) { build(:test_download_tubes_cgap, columns:) } it 'upload' do login_user(user) @@ -139,7 +139,7 @@ end context 'multiplexed tube sample manifest with tag sequences' do - let!(:user) { create :admin } + let!(:user) { create(:admin) } let(:columns) { SampleManifestExcel.configuration.columns.tube_multiplexed_library_with_tag_sequences.dup } let(:test_file) { 'test_file.xlsx' } @@ -280,7 +280,7 @@ end context 'multiplexed tube sample manifest with tag groups and indexes' do - let!(:user) { create :admin } + let!(:user) { create(:admin) } let(:columns) { SampleManifestExcel.configuration.columns.tube_multiplexed_library.dup } let(:test_file) { 'test_file.xlsx' } @@ -413,7 +413,7 @@ end context 'plate sample manifest' do - let!(:user) { create :admin } + let!(:user) { create(:admin) } let(:columns) { SampleManifestExcel.configuration.columns.plate_default.dup } let(:test_file) { 'test_file.xlsx' } @@ -424,7 +424,7 @@ context 'valid' do context 'standard' do - let(:download) { build(:test_download_plates, columns: columns) } + let(:download) { build(:test_download_plates, columns:) } it 'upload' do login_user(user) @@ -436,7 +436,7 @@ end context 'partial' do - let(:download) { build(:test_download_plates_partial, columns: columns) } + let(:download) { build(:test_download_plates_partial, columns:) } it 'upload' do login_user(user) @@ -448,7 +448,7 @@ end context 'cgap foreign barcodes' do - let(:download) { build(:test_download_plates_cgap, columns: columns) } + let(:download) { build(:test_download_plates_cgap, columns:) } it 'upload' do login_user(user) @@ -460,7 +460,7 @@ end context 'cgap foreign barcodes partial' do - let(:download) { build(:test_download_plates_partial_cgap, columns: columns) } + let(:download) { build(:test_download_plates_partial_cgap, columns:) } it 'upload' do login_user(user) @@ -474,7 +474,7 @@ context 'invalid' do context 'no file' do - let(:download) { build(:test_download_plates, columns: columns) } + let(:download) { build(:test_download_plates, columns:) } it 'no file' do login_user(user) diff --git a/spec/features/shared_examples/sequencing.rb b/spec/features/shared_examples/sequencing.rb index 3e53228444..e7baf91b2a 100644 --- a/spec/features/shared_examples/sequencing.rb +++ b/spec/features/shared_examples/sequencing.rb @@ -66,7 +66,7 @@ go_back all(:link, 'Lane').last.click - expect(page).not_to have_content('Spiked Buffer') + expect(page).to have_no_content('Spiked Buffer') batch = Batch.last flowcell_message = batch.messengers.last diff --git a/spec/features/starting_transfers_on_repools_starts_repools_spec.rb b/spec/features/starting_transfers_on_repools_starts_repools_spec.rb index 332f671dea..1b78973926 100644 --- a/spec/features/starting_transfers_on_repools_starts_repools_spec.rb +++ b/spec/features/starting_transfers_on_repools_starts_repools_spec.rb @@ -18,10 +18,10 @@ require 'rails_helper' describe 'Starting transfers on repools starts repools' do - let(:original_input_plate) { create :input_plate_for_pooling } + let(:original_input_plate) { create(:input_plate_for_pooling) } let(:secondary_input_plate) do plate = PlateCreation.create!(user: user, parent: original_input_plate, child_purpose: create(:plate_purpose)).child - create :transfer_between_plates, source: original_input_plate, destination: plate + create(:transfer_between_plates, source: original_input_plate, destination: plate) plate end @@ -29,15 +29,15 @@ PlateCreation.create!(user: user, parent: original_input_plate, child_purpose: create(:plate_purpose)).child end - let(:user) { create :user } + let(:user) { create(:user) } let(:source_a1) { secondary_input_plate.wells.detect { |w| w.map_description == 'A1' } } let(:source_b1) { secondary_input_plate.wells.detect { |w| w.map_description == 'B1' } } let(:target_a1) { target_plate.wells.detect { |w| w.map_description == 'A1' } } let(:target_b1) { target_plate.wells.detect { |w| w.map_description == 'B1' } } - let(:library_creation_request_a1) { create :library_creation_request, asset: source_a1 } - let(:library_creation_request_b1) { create :library_creation_request, asset: source_b1 } + let(:library_creation_request_a1) { create(:library_creation_request, asset: source_a1) } + let(:library_creation_request_b1) { create(:library_creation_request, asset: source_b1) } before do allow(PlateBarcode).to receive(:create_barcode).and_return(build(:plate_barcode), build(:plate_barcode)) diff --git a/spec/features/studies/change_study_roles_spec.rb b/spec/features/studies/change_study_roles_spec.rb index 495434151a..2c2823d7bf 100644 --- a/spec/features/studies/change_study_roles_spec.rb +++ b/spec/features/studies/change_study_roles_spec.rb @@ -3,8 +3,8 @@ require 'rails_helper' describe 'Study roles' do - let(:user) { create :admin } - let!(:study) { create :study_with_manager, updated_at: 1.year.ago } + let(:user) { create(:admin) } + let!(:study) { create(:study_with_manager, updated_at: 1.year.ago) } let(:manager) { study.managers.first } it 'can be removed', :js do @@ -16,7 +16,7 @@ click_link 'Contacts' expect(find_by_id('role_list')).to have_content(manager.login) click_button 'Remove' - expect(find_by_id('role_list')).not_to have_content(manager.login) + expect(find_by_id('role_list')).to have_no_content(manager.login) expect(study.reload.updated_at).to be > 1.hour.ago end end diff --git a/spec/features/studies/create_study_spec.rb b/spec/features/studies/create_study_spec.rb index 4500a0bc25..4f63079c5b 100644 --- a/spec/features/studies/create_study_spec.rb +++ b/spec/features/studies/create_study_spec.rb @@ -3,13 +3,13 @@ require 'rails_helper' describe 'Create a study' do - let(:user) { create :admin } + let(:user) { create(:admin) } before do - create :faculty_sponsor, name: 'Jack Sponsor' - create :data_release_study_type, name: 'genomic sequencing' - create :study_type - create :program + create(:faculty_sponsor, name: 'Jack Sponsor') + create(:data_release_study_type, name: 'genomic sequencing') + create(:study_type) + create(:program) end it 'displays the expected fields' do @@ -66,7 +66,7 @@ choose('Managed (EGA)', allow_label_click: true) expect(page).to have_content('HuMFre approval number') click_button 'Create' - expect(page).not_to have_content "Study metadata HuMFre approval number can't be blank" + expect(page).to have_no_content "Study metadata HuMFre approval number can't be blank" end it 'create open study', :js do diff --git a/spec/features/studies/edit_study_spec.rb b/spec/features/studies/edit_study_spec.rb index 89f7649b3a..c8a29b8138 100644 --- a/spec/features/studies/edit_study_spec.rb +++ b/spec/features/studies/edit_study_spec.rb @@ -3,8 +3,8 @@ require 'rails_helper' describe 'Edit a study' do - let(:user) { create :admin } - let!(:study) { create :study } + let(:user) { create(:admin) } + let!(:study) { create(:study) } it 'edit open study', :js do study.study_metadata.bam = false @@ -36,7 +36,7 @@ end context 'when data release strategy is Not Applicable' do - let!(:study) { create :not_app_study } + let!(:study) { create(:not_app_study) } it 'does not error when setting strategy to Open', :js do study.study_metadata.data_release_strategy = 'not applicable' diff --git a/spec/features/studies/manage_study_spec.rb b/spec/features/studies/manage_study_spec.rb index c5f242150a..a6a1a094c3 100644 --- a/spec/features/studies/manage_study_spec.rb +++ b/spec/features/studies/manage_study_spec.rb @@ -3,8 +3,8 @@ require 'rails_helper' describe 'Manage a study' do - let(:user) { create :admin } - let!(:study) { create :study, name: 'Original name' } + let(:user) { create(:admin) } + let!(:study) { create(:study, name: 'Original name') } it 'Rename a study', :js do login_user(user) @@ -14,7 +14,7 @@ fill_in 'Study name', with: 'Updated name' click_on 'Update' expect(page).to have_content('Updated name') - expect(page).not_to have_content('Original name') + expect(page).to have_no_content('Original name') end context 'with data release strategy' do diff --git a/spec/features/studies/qc_reports_spec.rb b/spec/features/studies/qc_reports_spec.rb index b132ba7cf2..59ddcdd4e7 100644 --- a/spec/features/studies/qc_reports_spec.rb +++ b/spec/features/studies/qc_reports_spec.rb @@ -6,7 +6,7 @@ let(:user) { create(:admin) } let!(:study) { create(:study) } let!(:product_criteria) { create(:product_criteria) } - let(:plate_purposes) { create_list :plate_purpose, 3 } + let(:plate_purposes) { create_list(:plate_purpose, 3) } let(:plate_purpose_names) { plate_purposes.map(&:name) } before do diff --git a/spec/features/studies/view_study_properties_spec.rb b/spec/features/studies/view_study_properties_spec.rb index ddcb944ef6..a3359f72ac 100644 --- a/spec/features/studies/view_study_properties_spec.rb +++ b/spec/features/studies/view_study_properties_spec.rb @@ -3,9 +3,9 @@ require 'rails_helper' describe 'View study properties' do - let(:user) { create :admin } + let(:user) { create(:admin) } let(:prelim_id) { 'A1234' } - let(:study) { create(:study, study_metadata: create(:study_metadata, prelim_id: prelim_id)) } + let(:study) { create(:study, study_metadata: create(:study_metadata, prelim_id:)) } it 'view open study properties', :js do login_user(user) diff --git a/spec/features/studies/view_study_request_links_spec.rb b/spec/features/studies/view_study_request_links_spec.rb index 764090be4e..4134e1c15f 100644 --- a/spec/features/studies/view_study_request_links_spec.rb +++ b/spec/features/studies/view_study_request_links_spec.rb @@ -3,10 +3,10 @@ require 'rails_helper' describe 'View study properties' do - let(:user) { create :admin } + let(:user) { create(:admin) } let(:study) { create(:study, name: 'Study 3871492') } let(:sample) { create(:sample, name: 'sample_1-3871492') } - let(:sequencing_request_type) { create :sequencing_request_type } + let(:sequencing_request_type) { create(:sequencing_request_type) } let(:single_request) do create( :sequencing_request, @@ -17,7 +17,7 @@ ) end let(:library_tube) { create(:library_tube, samples: [sample], study: study) } - let(:sample_tube) { create(:sample_tube, sample: sample, study: study) } + let(:sample_tube) { create(:sample_tube, sample:, study:) } before do user @@ -38,7 +38,7 @@ it 'No links to absent requests', :js do click_link sequencing_request_type.name - expect(page).not_to have_link(title: "#{library_tube.human_barcode} started") + expect(page).to have_no_link(title: "#{library_tube.human_barcode} started") end it 'Single requests link directly to the request', :js do @@ -65,7 +65,7 @@ select('Library tube', from: 'Filter by') expect(page).to have_text 'Currently showing Library tube' within '#summary' do - expect(page).not_to have_text sample_tube.name + expect(page).to have_no_text sample_tube.name expect(page).to have_text library_tube.name end end diff --git a/spec/features/submissions/bulk_submissions_spec.rb b/spec/features/submissions/bulk_submissions_spec.rb index 7b90879579..debb336849 100644 --- a/spec/features/submissions/bulk_submissions_spec.rb +++ b/spec/features/submissions/bulk_submissions_spec.rb @@ -3,8 +3,8 @@ require 'rails_helper' describe 'Bulk submission', js: false do - let(:user) { create :admin, login: 'user' } - let(:study) { create :study, name: 'abc123_study' } + let(:user) { create(:admin, login: 'user') } + let(:study) { create(:study, name: 'abc123_study') } def process_submission(filename, encoding = nil) attach_file('bulk_submission_spreadsheet', Rails.root.join('features', 'submission', 'csv', filename)) @@ -14,11 +14,11 @@ def process_submission(filename, encoding = nil) before do login_user user - create :project, name: 'Test project' - create :asset_group, name: 'assetgroup123', study: study, asset_count: 2 + create(:project, name: 'Test project') + create(:asset_group, name: 'assetgroup123', study: study, asset_count: 2) visit bulk_submissions_path expect(page).to have_content('Bulk Submission New') - create :library_type, name: 'Standard' + create(:library_type, name: 'Standard') end shared_examples 'bulk submission file upload' do @@ -29,8 +29,8 @@ def process_submission(filename, encoding = nil) end end - let(:library_request_type) { create :library_request_type } - let(:sequencing_request_type) { create :sequencing_request_type, read_lengths: [100], default: 100 } + let(:library_request_type) { create(:library_request_type) } + let(:sequencing_request_type) { create(:sequencing_request_type, read_lengths: [100], default: 100) } let(:submission_template_hash) do { diff --git a/spec/features/tag_group_spec.rb b/spec/features/tag_group_spec.rb index a2bb3e6a2a..3065d7cafa 100644 --- a/spec/features/tag_group_spec.rb +++ b/spec/features/tag_group_spec.rb @@ -3,9 +3,9 @@ require 'rails_helper' describe 'Create a new tag group' do - let(:user) { create :admin } + let(:user) { create(:admin) } - before { create :adapter_type, name: 'My type' } + before { create(:adapter_type, name: 'My type') } it 'view tag groups and create a new valid one' do login_user user diff --git a/spec/features/tag_layout_template_spec.rb b/spec/features/tag_layout_template_spec.rb index 923ab8c783..2219bfcb9e 100644 --- a/spec/features/tag_layout_template_spec.rb +++ b/spec/features/tag_layout_template_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' describe 'Create a new tag layout template' do - let(:user) { create :admin } + let(:user) { create(:admin) } let(:tag_group_1) { create(:tag_group_with_tags, name: 'Test tag group 1') } let(:tag_group_2) { create(:tag_group_with_tags, name: 'Test tag group 2') } let(:tag_set_1) { create(:tag_set, name: 'Test tag set 1') } diff --git a/spec/features/tag_set_spec.rb b/spec/features/tag_set_spec.rb index c210cf54de..5554c2de5f 100644 --- a/spec/features/tag_set_spec.rb +++ b/spec/features/tag_set_spec.rb @@ -3,10 +3,10 @@ require 'rails_helper' describe 'Create a new tag set' do - let(:user) { create :admin } - let(:adapter_type) { create :adapter_type } - let(:tag_group) { create :tag_group, name: 'test-group-1', adapter_type: adapter_type } - let(:tag2_group) { create :tag_group, name: 'test-group-2', adapter_type: adapter_type } + let(:user) { create(:admin) } + let(:adapter_type) { create(:adapter_type) } + let(:tag_group) { create(:tag_group, name: 'test-group-1', adapter_type: adapter_type) } + let(:tag2_group) { create(:tag_group, name: 'test-group-2', adapter_type: adapter_type) } before do tag_group diff --git a/spec/helpers/assets_helper_spec.rb b/spec/helpers/assets_helper_spec.rb index bda85472a0..eca5ec8d53 100644 --- a/spec/helpers/assets_helper_spec.rb +++ b/spec/helpers/assets_helper_spec.rb @@ -14,37 +14,37 @@ subject { helper.current_user_can_request_additional_sequencing_on?(asset) } context 'an admin user' do - let(:user) { create :admin } + let(:user) { create(:admin) } context 'with a SampleTube' do - let(:asset) { create :sample_tube } + let(:asset) { create(:sample_tube) } it { is_expected.to be false } end context 'with a LibraryTube' do - let(:asset) { create :library_tube } + let(:asset) { create(:library_tube) } it { is_expected.to be true } end context 'with a MultiplexedTube' do - let(:asset) { create :multiplexed_library_tube } + let(:asset) { create(:multiplexed_library_tube) } it { is_expected.to be true } end end context 'a manager' do - let(:user) { create :manager } - let(:asset) { create :library_tube } + let(:user) { create(:manager) } + let(:asset) { create(:library_tube) } it { is_expected.to be true } end context 'a regular user' do - let(:user) { create :user } - let(:asset) { create :library_tube } + let(:user) { create(:user) } + let(:asset) { create(:library_tube) } it { is_expected.to be false } end @@ -54,30 +54,30 @@ subject { helper.current_user_can_request_additional_library_on?(asset) } context 'an admin user' do - let(:user) { create :admin } + let(:user) { create(:admin) } context 'with a SampleTube' do - let(:asset) { create :sample_tube } + let(:asset) { create(:sample_tube) } it { is_expected.to be true } end context 'with a LibraryTube' do - let(:asset) { create :library_tube } + let(:asset) { create(:library_tube) } it { is_expected.to be false } end context 'with a MultiplexedTube' do - let(:asset) { create :multiplexed_library_tube } + let(:asset) { create(:multiplexed_library_tube) } it { is_expected.to be false } end end context 'with a manager' do - let(:user) { create :manager } - let(:asset) { create :sample_tube } + let(:user) { create(:manager) } + let(:asset) { create(:sample_tube) } # NOTE: This behaviour changes with the permissions update to be consistent # with sequencing. @@ -86,8 +86,8 @@ end context 'with a regular user' do - let(:user) { create :user } - let(:asset) { create :sample_tube } + let(:user) { create(:user) } + let(:asset) { create(:sample_tube) } it { is_expected.to be false } end diff --git a/spec/helpers/batches_helper_spec.rb b/spec/helpers/batches_helper_spec.rb index 78e7963e1d..519b6cade0 100644 --- a/spec/helpers/batches_helper_spec.rb +++ b/spec/helpers/batches_helper_spec.rb @@ -8,7 +8,7 @@ subject { subject { helper.each_action(batch) } } context 'with a pending batch' do - let(:batch) { build :batch, state: 'pending' } + let(:batch) { build(:batch, state: 'pending') } let(:fail_link) do [ 'Fail batch or requests', @@ -24,7 +24,7 @@ end context 'with a release batch' do - let(:batch) { build_stubbed :batch, state: 'released' } + let(:batch) { build_stubbed(:batch, state: 'released') } let(:fail_link) { ['Fail batch or requests', { action: :fail, id: batch.id }, true, nil] } it 'yields an active fail link' do @@ -37,7 +37,7 @@ def stage_link(id) { action: :stage, batch_id: nil, controller: :workflows, id: id, workflow_id: pipeline.workflow.id } end let(:pipeline) { create(:sequencing_pipeline, :with_workflow) } - let(:batch) { build :batch, state: 'pending', pipeline: pipeline } + let(:batch) { build(:batch, state: 'pending', pipeline: pipeline) } let(:task1) { ['Specify Dilution Volume', stage_link(0), true, nil] } let(:task2) { ['Add Spiked in control', stage_link(1), true, nil] } diff --git a/spec/helpers/compound_sample_helper_spec.rb b/spec/helpers/compound_sample_helper_spec.rb index 19c073132b..6881e0b2ef 100644 --- a/spec/helpers/compound_sample_helper_spec.rb +++ b/spec/helpers/compound_sample_helper_spec.rb @@ -22,7 +22,7 @@ end context 'when a compound sample already exists' do - let!(:compound_sample) { create(:sample, component_samples: component_samples) } + let!(:compound_sample) { create(:sample, component_samples:) } it 'does not create a new compound sample' do expect { helper.find_or_create_compound_sample(study, component_samples) }.not_to change(Sample, :count) diff --git a/spec/helpers/deprecation_helper_spec.rb b/spec/helpers/deprecation_helper_spec.rb index 126a58b003..66eaab1a45 100644 --- a/spec/helpers/deprecation_helper_spec.rb +++ b/spec/helpers/deprecation_helper_spec.rb @@ -57,7 +57,7 @@ let(:expected_title) { 'Scheduled for removal in 2 days' } let(:expected_style) { 'danger' } - it { is_expected.not_to have_content('Deprecated content') } + it { is_expected.to have_no_content('Deprecated content') } end end end diff --git a/spec/heron/factories/concerns/contents_spec.rb b/spec/heron/factories/concerns/contents_spec.rb index 2542cf9330..64c4759bf0 100644 --- a/spec/heron/factories/concerns/contents_spec.rb +++ b/spec/heron/factories/concerns/contents_spec.rb @@ -29,7 +29,7 @@ def recipients_key end end let(:factory) { factory_klass.new(params) } - let(:study) { create :study } + let(:study) { create(:study) } include BarcodeHelper @@ -238,7 +238,7 @@ def recipients_key let(:tubes) do %w[A1 B1 C1].map do |coordinate| tube = create(:tube) - create(:racked_tube, tube: tube, coordinate: coordinate, tube_rack: tube_rack) + create(:racked_tube, tube:, coordinate:, tube_rack:) tube end end diff --git a/spec/heron/factories/concerns/eventful_spec.rb b/spec/heron/factories/concerns/eventful_spec.rb index 06b54f777f..8c9b4372bb 100644 --- a/spec/heron/factories/concerns/eventful_spec.rb +++ b/spec/heron/factories/concerns/eventful_spec.rb @@ -12,7 +12,7 @@ def initialize(params) end end - let(:plate) { create :plate } + let(:plate) { create(:plate) } let(:subjects) do [ build( @@ -25,7 +25,7 @@ def initialize(params) ] end let(:event_type) { BroadcastEvent::PlateCherrypicked::EVENT_TYPE } - let(:event) { { event: { event_type: event_type, subjects: subjects } } } + let(:event) { { event: { event_type:, subjects: } } } describe '#build_events' do it 'returns a list of events' do diff --git a/spec/heron/factories/event_spec.rb b/spec/heron/factories/event_spec.rb index a2c7bd759e..36b9737714 100644 --- a/spec/heron/factories/event_spec.rb +++ b/spec/heron/factories/event_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' RSpec.describe Heron::Factories::Event, :heron, :heron_events, type: :model do - let(:plate) { create :plate } + let(:plate) { create(:plate) } let(:subjects) do [ build( @@ -16,7 +16,7 @@ ] end let(:event_type) { BroadcastEvent::PlateCherrypicked::EVENT_TYPE } - let(:params) { { event: { event_type: event_type, subjects: subjects } } } + let(:params) { { event: { event_type:, subjects: } } } it 'is valid with all relevant attributes' do event = described_class.new(params, plate) diff --git a/spec/heron/factories/plate_from_rack_spec.rb b/spec/heron/factories/plate_from_rack_spec.rb index 8205c5ddd1..fc6a0f00b1 100644 --- a/spec/heron/factories/plate_from_rack_spec.rb +++ b/spec/heron/factories/plate_from_rack_spec.rb @@ -4,7 +4,7 @@ RSpec.describe Heron::Factories::PlateFromRack, :heron, type: :model do let(:purpose) { create(:plate_purpose, target_type: 'Plate', name: 'Stock Plate', size: '96') } - let(:rack) { create :tube_rack } + let(:rack) { create(:tube_rack) } let(:plate_factory) { described_class.new(tube_rack: rack, plate_purpose: purpose) } let(:tubes) { create_list(:sample_tube, 2) } diff --git a/spec/heron/factories/plate_spec.rb b/spec/heron/factories/plate_spec.rb index eb660d6396..b119a792cd 100644 --- a/spec/heron/factories/plate_spec.rb +++ b/spec/heron/factories/plate_spec.rb @@ -41,7 +41,7 @@ end context 'without a plate purpose uuid' do - let(:params) { { barcode: barcode } } + let(:params) { { barcode: } } let(:error_messages) { ['Plate purpose uuid not defined'] } it_behaves_like 'an invalid parameter' @@ -170,7 +170,7 @@ ] end let(:event_type) { BroadcastEvent::PlateCherrypicked::EVENT_TYPE } - let(:event) { { event: { event_type: event_type, subjects: subjects } } } + let(:event) { { event: { event_type:, subjects: } } } it 'can persist the events' do expect { plate_factory.save }.to change(BroadcastEvent, :count).by(1) diff --git a/spec/heron/factories/sample_spec.rb b/spec/heron/factories/sample_spec.rb index f52fe446d9..9ad572b0b9 100644 --- a/spec/heron/factories/sample_spec.rb +++ b/spec/heron/factories/sample_spec.rb @@ -3,11 +3,11 @@ require 'rails_helper' RSpec.describe Heron::Factories::Sample, :heron, :lighthouse, type: :model do - let(:study) { create :study } + let(:study) { create(:study) } describe '#valid?' do context 'when receiving a study instance' do - let(:params) { { study: study } } + let(:params) { { study: } } it 'is valid' do factory = described_class.new(params) @@ -80,9 +80,9 @@ describe '#create_aliquot_at' do context 'when the factory is valid' do - let(:well) { create :well } + let(:well) { create(:well) } let(:tag_id) { 1 } - let(:factory) { described_class.new(study: study, aliquot: { tag_id: tag_id }) } + let(:factory) { described_class.new(study: study, aliquot: { tag_id: }) } it 'can create an aliquot of the sample in the well' do expect { factory.create_aliquot_at(well) }.to change(Aliquot, :count).by(1).and(change(Sample, :count).by(1)) @@ -113,24 +113,24 @@ context 'when the factory is valid' do it 'returns a sample instance' do - factory = described_class.new(study: study) + factory = described_class.new(study:) expect(factory.create.class).to eq(Sample) end it 'returns the same sample instance in any subsequent call' do - factory = described_class.new(study: study) + factory = described_class.new(study:) sample = factory.create sample2 = factory.create expect(sample).to eq(sample2) end it 'creates one sample' do - factory = described_class.new(study: study) + factory = described_class.new(study:) expect { factory.create }.to change(Sample, :count).by(1) end it 'creates one uuid for the sample' do - factory = described_class.new(study: study) + factory = described_class.new(study:) sample = factory.create expect(Uuid.where(resource: sample).count).to eq(1) end @@ -196,7 +196,7 @@ end context 'when not providing a sanger_sample_id' do - let(:factory) { described_class.new(study: study) } + let(:factory) { described_class.new(study:) } it 'generates a new sanger_sample_id' do sample = nil @@ -228,7 +228,7 @@ end context 'when the uuid already exist' do - let(:sample) { create :sample } + let(:sample) { create(:sample) } it 'will be invalid if providing any other extra attributes' do factory = described_class.new(study: study, uuid: sample.uuid) diff --git a/spec/insdc/import_countries_spec.rb b/spec/insdc/import_countries_spec.rb index b61a65ebf9..628e5585bb 100644 --- a/spec/insdc/import_countries_spec.rb +++ b/spec/insdc/import_countries_spec.rb @@ -3,9 +3,7 @@ require 'rails_helper' RSpec.describe Insdc::ImportCountries do - subject(:importer) do - described_class.new(ena_root: ena_root, sample_checklist: sample_checklist, priorities: priorities) - end + subject(:importer) { described_class.new(ena_root:, sample_checklist:, priorities:) } before do # The File api is used heavily internally, and we're going to be mocking it a @@ -133,8 +131,8 @@ context 'when the file is present' do before do - create :insdc_country, name: 'Historic Coldland' - create :insdc_country, name: 'East Westland' + create(:insdc_country, name: 'Historic Coldland') + create(:insdc_country, name: 'East Westland') allow(File).to receive(:exist?).with(cached_file_path).and_return(true) allow(File).to receive(:open).with(cached_file_path).and_yield(mock_response) importer.import diff --git a/spec/jobs/export_pool_xp_to_traction_job_spec.rb b/spec/jobs/export_pool_xp_to_traction_job_spec.rb index 9eccdbb724..9ad95905d9 100644 --- a/spec/jobs/export_pool_xp_to_traction_job_spec.rb +++ b/spec/jobs/export_pool_xp_to_traction_job_spec.rb @@ -2,7 +2,7 @@ RSpec.describe ExportPoolXpToTractionJob, type: :job do let(:export_job) { described_class.new(tube.human_barcode) } - let(:tube) { create :multiplexed_library_tube, sample_count: 3 } + let(:tube) { create(:multiplexed_library_tube, sample_count: 3) } let(:schema_subject) { configatron.amqp.schemas.subjects[:export_pool_xp_to_traction][:subject] } let(:schema_version) { configatron.amqp.schemas.subjects[:export_pool_xp_to_traction][:version] } @@ -51,10 +51,10 @@ end describe '#get_message_data' do - let(:project) { create :project } + let(:project) { create(:project) } let(:actual_message) { export_job.get_message_data(tube.human_barcode) } - let(:study) { create :study } - let(:compound_sample) { create :sample } + let(:study) { create(:study) } + let(:compound_sample) { create(:sample) } before do allow(tube).to receive_messages(projects: [project], studies: [study]) diff --git a/spec/lib/ability_analysis_spec.rb b/spec/lib/ability_analysis_spec.rb index ffa11f9c73..fbf0cfb649 100644 --- a/spec/lib/ability_analysis_spec.rb +++ b/spec/lib/ability_analysis_spec.rb @@ -4,7 +4,7 @@ require 'spec_helper' RSpec.describe AbilityAnalysis do - subject(:ability_analysis) { described_class.new(roles: roles, ability: ability, permissions: permissions) } + subject(:ability_analysis) { described_class.new(roles:, ability:, permissions:) } let(:roles) { %w[role_a role_b] } let(:permissions) { { 'Study' => %i[edit read], 'Project' => %i[edit read] } } diff --git a/spec/lib/accession/sample_spec.rb b/spec/lib/accession/sample_spec.rb index 8872a1d7f8..8db1847c72 100644 --- a/spec/lib/accession/sample_spec.rb +++ b/spec/lib/accession/sample_spec.rb @@ -18,7 +18,7 @@ def find_value_at_tag(xml_received, tag_name) RSpec.describe Accession::Sample, :accession, type: :model do let(:tag_list) { build(:standard_accession_tag_list) } - before { @country = create :insdc_country, name: 'Australia' } + before { @country = create(:insdc_country, name: 'Australia') } it 'is not sent for accessioning if the sample has already been accessioned' do sample = @@ -41,7 +41,7 @@ def find_value_at_tag(xml_received, tag_name) expect(described_class.new(tag_list, sample)).not_to be_valid end - it "is not sent for accessioning if the sample doesn't have the required fields" do # rubocop:todo RSpec/ExampleLength + it "is not sent for accessioning if the sample doesn't have the required fields" do sample = create( :sample_for_accessioning_with_open_study, diff --git a/spec/lib/label_printer/asset_labels_spec.rb b/spec/lib/label_printer/asset_labels_spec.rb index 6e62bdec47..b19cea5239 100644 --- a/spec/lib/label_printer/asset_labels_spec.rb +++ b/spec/lib/label_printer/asset_labels_spec.rb @@ -19,9 +19,9 @@ end context 'printing plates' do - let(:asset1) { create :child_plate, name: 'Plate Name' } - let(:asset2) { create :child_plate, name: 'Plate Name' } - let(:asset3) { create :child_plate } + let(:asset1) { create(:child_plate, name: 'Plate Name') } + let(:asset2) { create(:child_plate, name: 'Plate Name') } + let(:asset3) { create(:child_plate) } let(:assets) { [asset1, asset2, asset3] } describe LabelPrinter::Label::AssetPlate do @@ -65,8 +65,8 @@ context 'printing tubes' do describe LabelPrinter::Label::AssetTube do - let(:asset1) { create :empty_sample_tube, barcode: '11111', name: 'Tube Name' } - let(:asset2) { create :empty_sample_tube } + let(:asset1) { create(:empty_sample_tube, barcode: '11111', name: 'Tube Name') } + let(:asset2) { create(:empty_sample_tube) } let(:assets) { [asset1, asset2] } let(:body) do diff --git a/spec/lib/label_printer/asset_redirect_spec.rb b/spec/lib/label_printer/asset_redirect_spec.rb index 32989723a7..26374c5402 100644 --- a/spec/lib/label_printer/asset_redirect_spec.rb +++ b/spec/lib/label_printer/asset_redirect_spec.rb @@ -49,18 +49,18 @@ describe LabelPrinter::Label::AssetRedirect do context 'printing plates' do - let(:asset1) { create :child_plate } - let(:asset2) { create :child_plate } - let(:asset3) { create :child_plate } + let(:asset1) { create(:child_plate) } + let(:asset2) { create(:child_plate) } + let(:asset3) { create(:child_plate) } it_behaves_like 'a correct filter' it_behaves_like 'a correct plate renderer' end context 'printing tubes' do - let(:asset1) { create :empty_sample_tube } - let(:asset2) { create :empty_sample_tube } - let(:asset3) { create :empty_sample_tube } + let(:asset1) { create(:empty_sample_tube) } + let(:asset2) { create(:empty_sample_tube) } + let(:asset3) { create(:empty_sample_tube) } it_behaves_like 'a correct filter' it_behaves_like 'a correct tube renderer' diff --git a/spec/lib/label_printer/batch_plate_spec.rb b/spec/lib/label_printer/batch_plate_spec.rb index 80808c8a14..9779791d45 100644 --- a/spec/lib/label_printer/batch_plate_spec.rb +++ b/spec/lib/label_printer/batch_plate_spec.rb @@ -62,8 +62,8 @@ let(:count) { '1' } let(:date_today) { Time.zone.today.strftime('%e-%^b-%Y') } - let(:batch) { create :batch } - let(:study) { create :study } + let(:batch) { create(:batch) } + let(:study) { create(:study) } let(:request1) do order = create(:order, order_role: OrderRole.new(role: 'test_role'), study: study, assets: [create(:empty_sample_tube)]) diff --git a/spec/lib/label_printer/sample_manifest_plate_double_spec.rb b/spec/lib/label_printer/sample_manifest_plate_double_spec.rb index d322b601c3..618e92e1be 100644 --- a/spec/lib/label_printer/sample_manifest_plate_double_spec.rb +++ b/spec/lib/label_printer/sample_manifest_plate_double_spec.rb @@ -5,8 +5,8 @@ describe LabelPrinter::Label::SampleManifestPlateDouble, :sample_manifest do subject { described_class.new(label_options) } - let(:sample_manifest) { create :pending_plate_sample_manifest } - let(:label_options) { { sample_manifest: sample_manifest, only_first_label: only_first_label } } + let(:sample_manifest) { create(:pending_plate_sample_manifest) } + let(:label_options) { { sample_manifest:, only_first_label: } } let(:sample_manifest_plates) { sample_manifest.printables } context 'printing only the first label' do diff --git a/spec/lib/label_printer/swipecard_spec.rb b/spec/lib/label_printer/swipecard_spec.rb index dcc8c16c09..cf225cb088 100644 --- a/spec/lib/label_printer/swipecard_spec.rb +++ b/spec/lib/label_printer/swipecard_spec.rb @@ -2,7 +2,7 @@ context 'when printing swipecard' do let(:barcode_printer_type) { create(:plate_barcode_printer_type) } - let(:barcode_printer) { create(:barcode_printer, barcode_printer_type: barcode_printer_type) } + let(:barcode_printer) { create(:barcode_printer, barcode_printer_type:) } let(:user) { create(:user) } let(:label_class) { LabelPrinter::Label::Swipecard } let(:label_template_name) { configatron.swipecard_pmb_template } diff --git a/spec/lib/mbrave_tags_creator_spec.rb b/spec/lib/mbrave_tags_creator_spec.rb index 2b438dae0e..8227af8382 100644 --- a/spec/lib/mbrave_tags_creator_spec.rb +++ b/spec/lib/mbrave_tags_creator_spec.rb @@ -95,7 +95,7 @@ it 'creates the tag group with the right indexing' do run_task %w[Bioscan_reverse_4_1_v1 Bioscan_reverse_4_2_v1].each do |name| - indexes = TagGroup.find_by(name: name).tags.map(&:map_id) + indexes = TagGroup.find_by(name:).tags.map(&:map_id) expect(indexes).to eq([1, 2, 3, 4]) end diff --git a/spec/lib/mock_parser.rb b/spec/lib/mock_parser.rb index b647bcdb5a..2b8e07af61 100644 --- a/spec/lib/mock_parser.rb +++ b/spec/lib/mock_parser.rb @@ -27,7 +27,7 @@ def assay_version '1.0' end - def each_well_and_parameters(&block) - @data.each(&block) + def each_well_and_parameters(&) + @data.each(&) end end diff --git a/spec/lib/populate_numer_of_samples_per_pool_spec.rb b/spec/lib/populate_numer_of_samples_per_pool_spec.rb new file mode 100644 index 0000000000..3686ce8d97 --- /dev/null +++ b/spec/lib/populate_numer_of_samples_per_pool_spec.rb @@ -0,0 +1,64 @@ +# frozen_string_literal: true + +# rubocop:disable RSpec/DescribeClass +require 'rails_helper' +require 'rake' + +RSpec.describe 'number_of_samples_per_pool:populate' do + def run_rake_task_with_args(task_name, *args) + Rake::Task[task_name].reenable + Rake.application.invoke_task("#{task_name}[#{args.join(',')}]") + end + + context 'when number of samples per pool rake task is invoked' do + let(:samples_per_pool) { 20 } + + before do + Rake.application.rake_require 'tasks/populate_number_of_samples_per_pool' + Rake::Task.define_task(:environment) + end + + it 'populating number of samples per pool' do + submission = create(:submission) + tube = create(:tube) + request = create(:well_request, asset: tube, submission: submission) + + # Execute + run_rake_task_with_args('number_of_samples_per_pool:populate', samples_per_pool, submission.reload.id) + + # Verify + expect(request.reload.request_metadata.number_of_samples_per_pool).to eq(samples_per_pool) + end + + it 'does not populate number of samples per pool when submission_id is nil' do + error_message = nil + + # Execute + begin + run_rake_task_with_args('number_of_samples_per_pool:populate', samples_per_pool, nil) + rescue StandardError => e + error_message = e.message + end + + # Verify + expect(error_message).to eq('Submission ID is missing') + end + + it 'does not populate number of samples per pool when samples_per_pool is nil' do + submission = create(:submission) + create(:tube) + error_message = nil + + # Execute + begin + run_rake_task_with_args('number_of_samples_per_pool:populate', nil, submission.reload.id) + rescue StandardError => e + error_message = e.message + end + + # Verify + expect(error_message).to eq('Number of samples per pool is missing') + end + end +end +# rubocop:enable RSpec/DescribeClass diff --git a/spec/lib/record_loader/pipeline_request_information_type_loader_spec.rb b/spec/lib/record_loader/pipeline_request_information_type_loader_spec.rb index a8e851a2b2..c40f32bae5 100644 --- a/spec/lib/record_loader/pipeline_request_information_type_loader_spec.rb +++ b/spec/lib/record_loader/pipeline_request_information_type_loader_spec.rb @@ -11,9 +11,9 @@ let(:test_directory) { Rails.root.join('spec/data/record_loader/pipeline_request_information_types') } before do - create :pipeline, name: 'Pipeline 1' - create :request_information_type, key: 'key' - create :request_information_type, key: 'key2' + create(:pipeline, name: 'Pipeline 1') + create(:request_information_type, key: 'key') + create(:request_information_type, key: 'key2') end context 'with two_entry_example selected' do diff --git a/spec/lib/record_loader/plate_purpose_loader_spec.rb b/spec/lib/record_loader/plate_purpose_loader_spec.rb index 5ae1e72eab..c79a889372 100644 --- a/spec/lib/record_loader/plate_purpose_loader_spec.rb +++ b/spec/lib/record_loader/plate_purpose_loader_spec.rb @@ -32,7 +32,7 @@ def a_new_record_loader context 'with a pre-existing plate' do before do - create :plate_purpose, name: created_purposes.first + create(:plate_purpose, name: created_purposes.first) subject.create! # rubocop:todo RSpec/NamedSubject end diff --git a/spec/lib/record_loader/request_type_loader_spec.rb b/spec/lib/record_loader/request_type_loader_spec.rb index b059bc6d32..9bca18c10c 100644 --- a/spec/lib/record_loader/request_type_loader_spec.rb +++ b/spec/lib/record_loader/request_type_loader_spec.rb @@ -12,8 +12,8 @@ def a_new_record_loader(files = selected_files) subject(:record_loader) { a_new_record_loader } before do - create :plate_purpose, name: 'Example purpose' - create :library_type, name: 'Standard' + create(:plate_purpose, name: 'Example purpose') + create(:library_type, name: 'Standard') end # Tests use a separate directory to avoid coupling your specs to the data @@ -69,7 +69,7 @@ def a_new_record_loader(files = selected_files) let(:selected_files) { 'request_types_updated' } before do - create :plate_purpose, name: 'Example purpose 2' + create(:plate_purpose, name: 'Example purpose 2') a_new_record_loader('request_types_basic').create! record_loader.create! end diff --git a/spec/lib/record_loader/robot_property_loader_spec.rb b/spec/lib/record_loader/robot_property_loader_spec.rb index 97f87216b8..d3dcbce4a9 100644 --- a/spec/lib/record_loader/robot_property_loader_spec.rb +++ b/spec/lib/record_loader/robot_property_loader_spec.rb @@ -18,8 +18,8 @@ def a_new_record_loader let(:selected_files) { 'robot_properties_example' } before do - create :robot, name: 'Robot 1' - create :robot, name: 'Robot 2' + create(:robot, name: 'Robot 1') + create(:robot, name: 'Robot 2') end it 'creates seven records' do diff --git a/spec/lib/record_loader/tag_group_loader_spec.rb b/spec/lib/record_loader/tag_group_loader_spec.rb index 26428c2b54..93f033ccd1 100644 --- a/spec/lib/record_loader/tag_group_loader_spec.rb +++ b/spec/lib/record_loader/tag_group_loader_spec.rb @@ -11,7 +11,7 @@ def a_new_record_loader subject(:record_loader) { a_new_record_loader } - before { create :adapter_type, name: 'Sanger 168' } + before { create(:adapter_type, name: 'Sanger 168') } # Tests use a separate directory to avoid coupling your specs to the data let(:test_directory) { Rails.root.join('spec/data/record_loader/tag_groups') } diff --git a/spec/lib/record_loader/tag_layout_templates_loader_spec.rb b/spec/lib/record_loader/tag_layout_templates_loader_spec.rb index d8a1e153bb..7596d212b5 100644 --- a/spec/lib/record_loader/tag_layout_templates_loader_spec.rb +++ b/spec/lib/record_loader/tag_layout_templates_loader_spec.rb @@ -26,8 +26,8 @@ def a_new_record_loader } end - let!(:tag_group) { create :tag_group, name: 'group 1' } - let!(:tag2_group) { create :tag_group, name: 'group 2' } + let!(:tag_group) { create(:tag_group, name: 'group 1') } + let!(:tag2_group) { create(:tag_group, name: 'group 2') } it 'creates two records' do expect { record_loader.create! }.to change(TagLayoutTemplate, :count).by(2) diff --git a/spec/mailers/user_query_mailer_spec.rb b/spec/mailers/user_query_mailer_spec.rb index 7723450765..61a4889995 100644 --- a/spec/mailers/user_query_mailer_spec.rb +++ b/spec/mailers/user_query_mailer_spec.rb @@ -12,7 +12,7 @@ after { Timecop.return } describe 'request for help' do - let!(:user_query) { build :user_query } + let!(:user_query) { build(:user_query) } let(:mail) { described_class.request_for_help(user_query) } let(:expected_body) { <<~HEREDOC } diff --git a/spec/models/ability_spec.rb b/spec/models/ability_spec.rb index 6aa59c748b..2f280b723c 100644 --- a/spec/models/ability_spec.rb +++ b/spec/models/ability_spec.rb @@ -137,7 +137,7 @@ def merge_permissions(*permissions) end context 'when there is a basic user' do - let(:user) { build :user } + let(:user) { build(:user) } let(:granted_permissions) { basic_permissions } @@ -145,7 +145,7 @@ def merge_permissions(*permissions) end context 'when the user has the role "administrator"' do - let(:user) { build :user, :with_role, role_name: 'administrator' } + let(:user) { build(:user, :with_role, role_name: 'administrator') } let(:granted_permissions) do merge_permissions( @@ -207,7 +207,7 @@ def merge_permissions(*permissions) end context 'when the user has the role "data_access_coordinator"' do - let(:user) { build :user, :with_role, role_name: 'data_access_coordinator' } + let(:user) { build(:user, :with_role, role_name: 'data_access_coordinator') } let(:granted_permissions) { merge_permissions(basic_permissions, { Study => %i[change_ethically_approved] }) } @@ -215,18 +215,18 @@ def merge_permissions(*permissions) end context 'when the user has the role "follower"' do - let(:user) { build :user, :with_role, role_name: 'follower' } + let(:user) { build(:user, :with_role, role_name: 'follower') } let(:granted_permissions) { basic_permissions } it_behaves_like 'it grants only granted_permissions' context 'with specific studies and projects' do - let(:user) { create :user, :with_role, role_name: 'follower' } - let(:authorized_project) { create :project, :with_follower, follower: user } - let(:unauthorized_project) { create :project } - let(:authorized_study) { create :study, :with_follower, follower: user } - let(:unauthorized_study) { create :study } + let(:user) { create(:user, :with_role, role_name: 'follower') } + let(:authorized_project) { create(:project, :with_follower, follower: user) } + let(:unauthorized_project) { create(:project) } + let(:authorized_study) { create(:study, :with_follower, follower: user) } + let(:unauthorized_study) { create(:study) } # Project it { is_expected.not_to be_able_to(:administer, authorized_project) } @@ -267,7 +267,7 @@ def merge_permissions(*permissions) end context 'when the user has the role "lab"' do - let(:user) { build :user, :with_role, role_name: 'lab' } + let(:user) { build(:user, :with_role, role_name: 'lab') } let(:granted_permissions) { basic_permissions } @@ -275,7 +275,7 @@ def merge_permissions(*permissions) end context 'when the user has the role "lab_manager"' do - let(:user) { build :user, :with_role, role_name: 'lab_manager' } + let(:user) { build(:user, :with_role, role_name: 'lab_manager') } let(:granted_permissions) do merge_permissions( @@ -294,7 +294,7 @@ def merge_permissions(*permissions) end context 'when the user has the role "manager"' do - let(:user) { build :user, :with_role, role_name: 'manager' } + let(:user) { build(:user, :with_role, role_name: 'manager') } let(:granted_permissions) do merge_permissions( @@ -318,11 +318,11 @@ def merge_permissions(*permissions) it_behaves_like 'it grants only granted_permissions' context 'with specific studies and projects' do - let(:user) { create :user, :with_role, role_name: 'manager' } - let(:authorized_project) { create :project, :with_manager, manager: user } - let(:unauthorized_project) { create :project } - let(:authorized_study) { create :study, :with_manager, manager: user } - let(:unauthorized_study) { create :study } + let(:user) { create(:user, :with_role, role_name: 'manager') } + let(:authorized_project) { create(:project, :with_manager, manager: user) } + let(:unauthorized_project) { create(:project) } + let(:authorized_study) { create(:study, :with_manager, manager: user) } + let(:unauthorized_study) { create(:study) } # Project it { is_expected.not_to be_able_to(:administer, authorized_project) } @@ -363,20 +363,20 @@ def merge_permissions(*permissions) end context 'when the user has the role "owner"' do - let(:user) { build :user, :with_role, role_name: 'owner' } + let(:user) { build(:user, :with_role, role_name: 'owner') } let(:granted_permissions) { basic_permissions } it_behaves_like 'it grants only granted_permissions' context 'with specific studies and projects' do - let(:user) { create :user, :with_role, role_name: 'owner' } - let(:authorized_project) { create :project, :with_owner, owner: user } - let(:unauthorized_project) { create :project } - let(:authorized_sample) { create :sample, :with_owner, owner: user } - let(:unauthorized_sample) { create :sample } - let(:authorized_study) { create :study, :with_owner, owner: user } - let(:unauthorized_study) { create :study } + let(:user) { create(:user, :with_role, role_name: 'owner') } + let(:authorized_project) { create(:project, :with_owner, owner: user) } + let(:unauthorized_project) { create(:project) } + let(:authorized_sample) { create(:sample, :with_owner, owner: user) } + let(:unauthorized_sample) { create(:sample) } + let(:authorized_study) { create(:study, :with_owner, owner: user) } + let(:unauthorized_study) { create(:study) } # Project it { is_expected.not_to be_able_to(:administer, authorized_project) } @@ -427,7 +427,7 @@ def merge_permissions(*permissions) end context 'when the user has the role "qa_manager"' do - let(:user) { build :user, :with_role, role_name: 'qa_manager' } + let(:user) { build(:user, :with_role, role_name: 'qa_manager') } let(:granted_permissions) { merge_permissions(basic_permissions, { QcDecision => %i[create new] }) } @@ -435,7 +435,7 @@ def merge_permissions(*permissions) end context 'when the user has the role "slf_gel"' do - let(:user) { build :user, :with_role, role_name: 'slf_gel' } + let(:user) { build(:user, :with_role, role_name: 'slf_gel') } let(:granted_permissions) do merge_permissions( @@ -448,7 +448,7 @@ def merge_permissions(*permissions) end context 'when the user has the role "slf_manager"' do - let(:user) { build :user, :with_role, role_name: 'slf_manager' } + let(:user) { build(:user, :with_role, role_name: 'slf_manager') } let(:granted_permissions) do merge_permissions( diff --git a/spec/models/aliquot_spec.rb b/spec/models/aliquot_spec.rb index a1499fdf2d..32c2fb1dd6 100644 --- a/spec/models/aliquot_spec.rb +++ b/spec/models/aliquot_spec.rb @@ -3,64 +3,64 @@ require 'rails_helper' RSpec.describe Aliquot do - let(:tag1) { create :tag } - let(:tag2) { create :tag } - let(:sample1) { create :sample } - let(:sample2) { create :sample } + let(:tag1) { create(:tag) } + let(:tag2) { create(:tag) } + let(:sample1) { create(:sample) } + let(:sample2) { create(:sample) } shared_context 'a tag matcher' do context 'with the same tags' do - let(:aliquot1) { build :aliquot, tag: tag1, tag2: tag1, sample: sample1 } - let(:aliquot2) { build :aliquot, tag: tag1, tag2: tag1, sample: sample1 } + let(:aliquot1) { build(:aliquot, tag: tag1, tag2: tag1, sample: sample1) } + let(:aliquot2) { build(:aliquot, tag: tag1, tag2: tag1, sample: sample1) } it { is_expected.to be true } end context 'with different tags' do - let(:aliquot1) { build :aliquot, tag: tag1, tag2: tag1, sample: sample1 } - let(:aliquot2) { build :aliquot, tag: tag2, tag2: tag1, sample: sample1 } + let(:aliquot1) { build(:aliquot, tag: tag1, tag2: tag1, sample: sample1) } + let(:aliquot2) { build(:aliquot, tag: tag2, tag2: tag1, sample: sample1) } it { is_expected.to be false } end context 'with different tag 2' do - let(:aliquot1) { build :aliquot, tag: tag1, tag2: tag1, sample: sample1 } - let(:aliquot2) { build :aliquot, tag: tag1, tag2: tag2, sample: sample1 } + let(:aliquot1) { build(:aliquot, tag: tag1, tag2: tag1, sample: sample1) } + let(:aliquot2) { build(:aliquot, tag: tag1, tag2: tag2, sample: sample1) } it { is_expected.to be false } end context 'with missing tags' do - let(:aliquot1) { build :aliquot, tag: tag1, tag2_id: -1, sample: sample1 } - let(:aliquot2) { build :aliquot, tag: nil, tag2_id: -1, sample: sample1 } + let(:aliquot1) { build(:aliquot, tag: tag1, tag2_id: -1, sample: sample1) } + let(:aliquot2) { build(:aliquot, tag: nil, tag2_id: -1, sample: sample1) } it { is_expected.to be true } end context 'with missing tag 2' do - let(:aliquot1) { build :aliquot, tag: nil, tag2: tag1, sample: sample1 } - let(:aliquot2) { build :aliquot, tag: nil, tag2_id: -1, sample: sample1 } + let(:aliquot1) { build(:aliquot, tag: nil, tag2: tag1, sample: sample1) } + let(:aliquot2) { build(:aliquot, tag: nil, tag2_id: -1, sample: sample1) } it { is_expected.to be true } end context 'with missing tags but present tag 2s' do - let(:aliquot1) { build :aliquot, tag: tag1, tag2: tag1, sample: sample1 } - let(:aliquot2) { build :aliquot, tag: nil, tag2: tag1, sample: sample1 } + let(:aliquot1) { build(:aliquot, tag: tag1, tag2: tag1, sample: sample1) } + let(:aliquot2) { build(:aliquot, tag: nil, tag2: tag1, sample: sample1) } it { is_expected.to be true } end context 'with missing tag 2s but present tags' do - let(:aliquot1) { build :aliquot, tag: tag1, tag2: tag1, sample: sample1 } - let(:aliquot2) { build :aliquot, tag: tag1, tag2_id: -1, sample: sample1 } + let(:aliquot1) { build(:aliquot, tag: tag1, tag2: tag1, sample: sample1) } + let(:aliquot2) { build(:aliquot, tag: tag1, tag2_id: -1, sample: sample1) } it { is_expected.to be true } end context 'with different samples' do - let(:aliquot1) { build :aliquot, tag: tag1, tag2: tag1, sample: sample1 } - let(:aliquot2) { build :aliquot, tag: tag1, tag2: tag1, sample: sample2 } + let(:aliquot1) { build(:aliquot, tag: tag1, tag2: tag1, sample: sample1) } + let(:aliquot2) { build(:aliquot, tag: tag1, tag2: tag1, sample: sample2) } it { is_expected.to be false } end @@ -74,7 +74,7 @@ end context 'mixing tests' do - let(:asset) { create :empty_well } + let(:asset) { create(:empty_well) } it 'allows mixing different tags with no tag2' do asset.aliquots << build(:aliquot, tag: tag1, sample: sample1) << build(:aliquot, tag: tag2, sample: sample2) @@ -95,11 +95,11 @@ end describe '#set_library' do - subject { build :aliquot, receptacle: receptacle, library_id: initial_library_id } + subject { build(:aliquot, receptacle: receptacle, library_id: initial_library_id) } - let(:receptacle) { create :empty_well } + let(:receptacle) { create(:empty_well) } - before { subject.set_library(force: force) } + before { subject.set_library(force:) } context 'when not set' do let(:force) { false } @@ -131,7 +131,7 @@ describe 'for tags substitution' do it 'generates correct substitution hash' do - aliquot = create :aliquot + aliquot = create(:aliquot) tag_id = aliquot.tag_id expect(aliquot.substitution_hash).to be_nil aliquot.update!(tag_id: 42, insert_size_from: 5, insert_size_to: 15) @@ -152,7 +152,7 @@ aliquots.first.update!(project: nil) aliquots.second.project.project_metadata.update!(project_cost_code: 'new_cost_code') default_project_cost_code = aliquots.last.project.project_metadata.project_cost_code - receptacle = create :empty_well + receptacle = create(:empty_well) receptacle.aliquots << aliquots expect(receptacle.aliquots.count_by_project_cost_code).to eq( 'new_cost_code' => 1, diff --git a/spec/models/api/aliquot_io_spec.rb b/spec/models/api/aliquot_io_spec.rb index 722ac20093..38fa525df5 100644 --- a/spec/models/api/aliquot_io_spec.rb +++ b/spec/models/api/aliquot_io_spec.rb @@ -4,24 +4,26 @@ RSpec.describe Api::AliquotIO do subject do - create :aliquot, - receptacle: well, - sample: sample, - study: study, - project: project, - library: well, - tag: tag, - insert_size_from: 100, - insert_size_to: 200, - bait_library: bait_library + create( + :aliquot, + receptacle: well, + sample: sample, + study: study, + project: project, + library: well, + tag: tag, + insert_size_from: 100, + insert_size_to: 200, + bait_library: bait_library + ) end - let(:well) { create :empty_well } - let(:sample) { create :sample } - let(:study) { create :study } - let(:project) { create :project } - let(:tag) { create :tag } - let(:bait_library) { create :bait_library } + let(:well) { create(:empty_well) } + let(:sample) { create(:sample) } + let(:study) { create(:study) } + let(:project) { create(:project) } + let(:tag) { create(:tag) } + let(:bait_library) { create(:bait_library) } let(:expected_json) do { @@ -55,7 +57,7 @@ it_behaves_like('an IO object') context 'with minimal data' do - subject { create :minimal_aliquot } + subject { create(:minimal_aliquot) } let(:expected_json) do { diff --git a/spec/models/api/asset_link_io_spec.rb b/spec/models/api/asset_link_io_spec.rb index 536ecde75a..b93a944ebc 100644 --- a/spec/models/api/asset_link_io_spec.rb +++ b/spec/models/api/asset_link_io_spec.rb @@ -3,10 +3,10 @@ require 'rails_helper' RSpec.describe Api::AssetLinkIO do - subject { create :asset_link, ancestor: ancestor, descendant: descendant } + subject { create(:asset_link, ancestor:, descendant:) } - let(:ancestor) { create :sample_tube } - let(:descendant) { create :multiplexed_library_tube } + let(:ancestor) { create(:sample_tube) } + let(:descendant) { create(:multiplexed_library_tube) } let(:expected_json) do { diff --git a/spec/models/api/batch_io_spec.rb b/spec/models/api/batch_io_spec.rb index 80dd898569..015a8ffddc 100644 --- a/spec/models/api/batch_io_spec.rb +++ b/spec/models/api/batch_io_spec.rb @@ -3,11 +3,11 @@ require 'rails_helper' RSpec.describe Api::BatchIO do - subject { create :batch, user: user, assignee: user2, pipeline: pipeline } + subject { create(:batch, user: user, assignee: user2, pipeline: pipeline) } - let(:user) { create :user } - let(:user2) { create :user } - let(:pipeline) { create :pipeline } + let(:user) { create(:user) } + let(:user2) { create(:user) } + let(:pipeline) { create(:pipeline) } let(:expected_json) do { diff --git a/spec/models/api/batch_request_io_spec.rb b/spec/models/api/batch_request_io_spec.rb index 3cd2feb99c..ba7cde0c48 100644 --- a/spec/models/api/batch_request_io_spec.rb +++ b/spec/models/api/batch_request_io_spec.rb @@ -3,9 +3,9 @@ require 'rails_helper' RSpec.describe Api::BatchRequestIO do - subject { create :batch_request, request: request } + subject { create(:batch_request, request:) } - let(:request) { create :request } + let(:request) { create(:request) } let(:expected_json) do { diff --git a/spec/models/api/lane_io_spec.rb b/spec/models/api/lane_io_spec.rb index 775652514c..67770da453 100644 --- a/spec/models/api/lane_io_spec.rb +++ b/spec/models/api/lane_io_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' RSpec.describe Api::LaneIO do - subject { create :lane } + subject { create(:lane) } let(:expected_json) do { diff --git a/spec/models/api/library_tube_io_spec.rb b/spec/models/api/library_tube_io_spec.rb index 03470953e1..a9a2c3d72c 100644 --- a/spec/models/api/library_tube_io_spec.rb +++ b/spec/models/api/library_tube_io_spec.rb @@ -4,14 +4,14 @@ RSpec.describe Api::LibraryTubeIO do subject do - create :empty_library_tube, public_name: 'ABC', closed: false, aliquots: aliquots, volume: 12.0, concentration: 8.0 + create(:empty_library_tube, public_name: 'ABC', closed: false, aliquots: aliquots, volume: 12.0, concentration: 8.0) end - let(:sample) { create :sample } - let(:tag) { create :tag } + let(:sample) { create(:sample) } + let(:tag) { create(:tag) } let(:aliquots) { [create(:aliquot, sample: sample, tag: tag, library_type: 'Standard')] } - let!(:library_request) { create :library_creation_request, target_asset: subject } + let!(:library_request) { create(:library_creation_request, target_asset: subject) } let(:expected_json) do { diff --git a/spec/models/api/messages/flowcell_io_spec.rb b/spec/models/api/messages/flowcell_io_spec.rb index 993b851be2..b640c7c038 100644 --- a/spec/models/api/messages/flowcell_io_spec.rb +++ b/spec/models/api/messages/flowcell_io_spec.rb @@ -6,20 +6,22 @@ subject { described_class.to_hash(sequencing_batch.reload) } context 'with a batch' do - let(:sequencing_pipeline) { create :sequencing_pipeline } + let(:sequencing_pipeline) { create(:sequencing_pipeline) } - let(:sequencing_batch) { create :sequencing_batch, pipeline: sequencing_pipeline } + let(:sequencing_batch) { create(:sequencing_batch, pipeline: sequencing_pipeline) } let!(:request_1) do - create :complete_sequencing_request, - asset: mx_tube1, - batch: sequencing_batch, - target_asset: lane1, - request_type: request_type, - event_descriptors: request_data + create( + :complete_sequencing_request, + asset: mx_tube1, + batch: sequencing_batch, + target_asset: lane1, + request_type: request_type, + event_descriptors: request_data + ) end - let(:mx_tube1) { create :multiplexed_library_tube, sample_count: 1 } + let(:mx_tube1) { create(:multiplexed_library_tube, sample_count: 1) } let(:request_type) { sequencing_pipeline.request_types.first } @@ -32,7 +34,7 @@ end end - let(:phix) { create :spiked_buffer, :tube_barcode, tag_option: 'Dual' } + let(:phix) { create(:spiked_buffer, :tube_barcode, tag_option: 'Dual') } let(:tags) { lane1.aliquots.map(&:tag) } let(:tag2s) { lane1.aliquots.map(&:tag2) } @@ -50,15 +52,17 @@ context 'with updated events' do before do - create :lab_event, - eventful: request_1, - batch: request_1.batch, - descriptors: { - 'Chip Barcode' => 'new_fcb', - 'PhiX %' => '1', - 'Workflow (Standard or Xp)' => 'xp', - 'Lane loading concentration (pM)' => '30' - } + create( + :lab_event, + eventful: request_1, + batch: request_1.batch, + descriptors: { + 'Chip Barcode' => 'new_fcb', + 'PhiX %' => '1', + 'Workflow (Standard or Xp)' => 'xp', + 'Lane loading concentration (pM)' => '30' + } + ) end let(:request_data) do @@ -306,7 +310,7 @@ end context 'when there are multiple SpikedBuffer ancestors' do - let(:phix) { create :spiked_buffer_with_parent, :tube_barcode } + let(:phix) { create(:spiked_buffer_with_parent, :tube_barcode) } # To test whether the PhiX barcode and aliquot come from the correct ancestor, # when the lane has multiple SpikedBuffer tube ancestors diff --git a/spec/models/api/messages/pac_bio_run_io_spec.rb b/spec/models/api/messages/pac_bio_run_io_spec.rb index 030bddec3c..14da4473c3 100644 --- a/spec/models/api/messages/pac_bio_run_io_spec.rb +++ b/spec/models/api/messages/pac_bio_run_io_spec.rb @@ -7,14 +7,14 @@ let(:plate) { create(:plate_with_tagged_wells, sample_count: 2) } - let(:aliquot_1) { create :tagged_aliquot } - let(:aliquot_2) { create :untagged_aliquot } + let(:aliquot_1) { create(:tagged_aliquot) } + let(:aliquot_2) { create(:untagged_aliquot) } - let(:library_tube_1) { create :pac_bio_library_tube, aliquot: aliquot_1 } - let(:library_tube_2) { create :pac_bio_library_tube, aliquot: aliquot_2 } + let(:library_tube_1) { create(:pac_bio_library_tube, aliquot: aliquot_1) } + let(:library_tube_2) { create(:pac_bio_library_tube, aliquot: aliquot_2) } let(:pac_bio_batch) do - batch = create :pac_bio_sequencing_batch, assets: [library_tube_1, library_tube_2], target_plate: plate + batch = create(:pac_bio_sequencing_batch, assets: [library_tube_1, library_tube_2], target_plate: plate) # Historically transfer was handled by the pipeline. But now we're keeping # this for update of legacy batches only. diff --git a/spec/models/api/messages/pac_bio_run_with_tag2_io_spec.rb b/spec/models/api/messages/pac_bio_run_with_tag2_io_spec.rb index e7b758ffec..aaf23347cd 100644 --- a/spec/models/api/messages/pac_bio_run_with_tag2_io_spec.rb +++ b/spec/models/api/messages/pac_bio_run_with_tag2_io_spec.rb @@ -7,14 +7,14 @@ let(:plate) { create(:plate_with_tagged_wells, sample_count: 2) } - let(:aliquot_1) { create :tagged_aliquot } - let(:aliquot_2) { create :untagged_aliquot } + let(:aliquot_1) { create(:tagged_aliquot) } + let(:aliquot_2) { create(:untagged_aliquot) } - let(:library_tube_1) { create :pac_bio_library_tube, aliquot: aliquot_1 } - let(:library_tube_2) { create :pac_bio_library_tube, aliquot: aliquot_2 } + let(:library_tube_1) { create(:pac_bio_library_tube, aliquot: aliquot_1) } + let(:library_tube_2) { create(:pac_bio_library_tube, aliquot: aliquot_2) } let(:pac_bio_batch) do - batch = create :pac_bio_sequencing_batch, assets: [library_tube_1, library_tube_2], target_plate: plate + batch = create(:pac_bio_sequencing_batch, assets: [library_tube_1, library_tube_2], target_plate: plate) batch.reload batch end diff --git a/spec/models/api/messages/qc_result_io_spec.rb b/spec/models/api/messages/qc_result_io_spec.rb index d527a0af7d..63e19b23f2 100644 --- a/spec/models/api/messages/qc_result_io_spec.rb +++ b/spec/models/api/messages/qc_result_io_spec.rb @@ -5,7 +5,7 @@ describe Api::Messages::QcResultIO do subject { described_class.to_hash(qc_result) } - let(:sample_tube) { create :sample_tube } + let(:sample_tube) { create(:sample_tube) } let(:expected_json) do { 'id_qc_result_lims' => qc_result.id, @@ -22,8 +22,8 @@ context 'the qc_result asset is a well' do let(:aliquots) { create_list(:aliquot, 1, library: sample_tube) } - let(:well) { create :well_with_sample_and_plate, aliquots: aliquots } - let(:qc_result) { create :qc_result, asset: well } + let(:well) { create(:well_with_sample_and_plate, aliquots:) } + let(:qc_result) { create(:qc_result, asset: well) } it 'generates a valid json' do actual = subject.as_json @@ -35,7 +35,7 @@ end context 'the qc_result asset is a multiplexed library tube' do - let(:qc_result) { create :qc_result, asset: sample_tube } + let(:qc_result) { create(:qc_result, asset: sample_tube) } it 'generates a valid json' do actual = subject.as_json diff --git a/spec/models/api/messages/well_stock_resource_io_spec.rb b/spec/models/api/messages/well_stock_resource_io_spec.rb index 575171a93c..aa59645660 100644 --- a/spec/models/api/messages/well_stock_resource_io_spec.rb +++ b/spec/models/api/messages/well_stock_resource_io_spec.rb @@ -10,16 +10,18 @@ after { Timecop.return } - let(:sample) { create :sample } + let(:sample) { create(:sample) } let(:plate_barcode) { build(:plate_barcode) } let(:well) do - create :well, - map: Map.find_by!(description: 'A1', asset_shape: AssetShape.default, asset_size: 96), - plate: create(:plate, barcode: plate_barcode.barcode), - well_attribute: create(:complete_well_attribute) + create( + :well, + map: Map.find_by!(description: 'A1', asset_shape: AssetShape.default, asset_size: 96), + plate: create(:plate, barcode: plate_barcode.barcode), + well_attribute: create(:complete_well_attribute) + ) end - let(:study) { create :study } - let(:aliquot) { create :aliquot, study: study, sample: sample, receptacle: well } + let(:study) { create(:study) } + let(:aliquot) { create(:aliquot, study: study, sample: sample, receptacle: well) } before { aliquot } # rubocop:todo RSpec/ScatteredSetup diff --git a/spec/models/api/multiplexed_library_tube_io_spec.rb b/spec/models/api/multiplexed_library_tube_io_spec.rb index 13c4737982..d8ac139272 100644 --- a/spec/models/api/multiplexed_library_tube_io_spec.rb +++ b/spec/models/api/multiplexed_library_tube_io_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' RSpec.describe Api::MultiplexedLibraryTubeIO do - subject { create :multiplexed_library_tube, volume: 12.0, concentration: 8.0 } + subject { create(:multiplexed_library_tube, volume: 12.0, concentration: 8.0) } let(:expected_json) do { diff --git a/spec/models/api/order_io_spec.rb b/spec/models/api/order_io_spec.rb index 9510c30222..de2090b395 100644 --- a/spec/models/api/order_io_spec.rb +++ b/spec/models/api/order_io_spec.rb @@ -4,26 +4,28 @@ RSpec.describe Api::OrderIO do subject do - create :order, - user: user, - template_name: 'Cool template', - study: study, - project: project, - comments: 'Good', - request_options: { - read_length: '200', - library_type: 'Standard', - fragment_size_required_from: '10', - fragment_size_required_to: '20', - bait_library_name: 'EG', - sequencing_type: 'MagBead', - insert_size: 12 - } + create( + :order, + user: user, + template_name: 'Cool template', + study: study, + project: project, + comments: 'Good', + request_options: { + read_length: '200', + library_type: 'Standard', + fragment_size_required_from: '10', + fragment_size_required_to: '20', + bait_library_name: 'EG', + sequencing_type: 'MagBead', + insert_size: 12 + } + ) end - let(:user) { create :user } - let(:study) { create :study } - let(:project) { create :project } + let(:user) { create(:user) } + let(:study) { create(:study) } + let(:project) { create(:project) } let(:expected_json) do { diff --git a/spec/models/api/pac_bio_library_tube_io_spec.rb b/spec/models/api/pac_bio_library_tube_io_spec.rb index 16d6a6a0e7..6fa6dd36fb 100644 --- a/spec/models/api/pac_bio_library_tube_io_spec.rb +++ b/spec/models/api/pac_bio_library_tube_io_spec.rb @@ -4,17 +4,19 @@ RSpec.describe Api::PacBioLibraryTubeIO do subject do - create :pac_bio_library_tube, - :scanned_into_lab, - concentration: 8.0, - volume: 12.0, - pac_bio_library_tube_metadata_attributes: { - prep_kit_barcode: 999, - binding_kit_barcode: 233, - smrt_cells_available: 5, - movie_length: 100, - protocol: 'xyzzy' - } + create( + :pac_bio_library_tube, + :scanned_into_lab, + concentration: 8.0, + volume: 12.0, + pac_bio_library_tube_metadata_attributes: { + prep_kit_barcode: 999, + binding_kit_barcode: 233, + smrt_cells_available: 5, + movie_length: 100, + protocol: 'xyzzy' + } + ) end let(:expected_json) do diff --git a/spec/models/api/plate_io_spec.rb b/spec/models/api/plate_io_spec.rb index bc7194052b..4c4c23743d 100644 --- a/spec/models/api/plate_io_spec.rb +++ b/spec/models/api/plate_io_spec.rb @@ -3,9 +3,9 @@ require 'rails_helper' RSpec.describe Api::PlateIO do - subject { create :plate, plate_purpose: purpose } + subject { create(:plate, plate_purpose: purpose) } - let(:purpose) { create :plate_purpose } + let(:purpose) { create(:plate_purpose) } let(:expected_json) do { @@ -22,7 +22,7 @@ it_behaves_like('an IO object') context 'with an infinium barcode' do - subject { create :plate, plate_purpose: purpose, infinium_barcode: 'WG1234567-DNA' } + subject { create(:plate, plate_purpose: purpose, infinium_barcode: 'WG1234567-DNA') } let(:expected_json) do { 'uuid' => subject.uuid, 'id' => subject.id, 'name' => subject.name, 'infinium_barcode' => 'WG1234567-DNA' } @@ -32,7 +32,7 @@ end context 'with an fluidigm barcode' do - subject { create :plate, plate_purpose: purpose, fluidigm_barcode: '1234567890' } + subject { create(:plate, plate_purpose: purpose, fluidigm_barcode: '1234567890') } let(:expected_json) do { 'uuid' => subject.uuid, 'id' => subject.id, 'name' => subject.name, 'fluidigm_barcode' => '1234567890' } diff --git a/spec/models/api/plate_purpose_io_spec.rb b/spec/models/api/plate_purpose_io_spec.rb index 22a1533546..14cab89d2d 100644 --- a/spec/models/api/plate_purpose_io_spec.rb +++ b/spec/models/api/plate_purpose_io_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' RSpec.describe Api::PlatePurposeIO do - subject { create :plate_purpose } + subject { create(:plate_purpose) } let(:expected_json) { { 'uuid' => subject.uuid, 'internal_id' => subject.id, 'name' => subject.name } } diff --git a/spec/models/api/project_io_spec.rb b/spec/models/api/project_io_spec.rb index 2d40938ddc..d22bcd815b 100644 --- a/spec/models/api/project_io_spec.rb +++ b/spec/models/api/project_io_spec.rb @@ -4,7 +4,7 @@ RSpec.describe Api::ProjectIO do context 'with minimal details' do - subject { create :project, approved: true } + subject { create(:project, approved: true) } let(:metadata) { subject.project_metadata } @@ -31,19 +31,21 @@ context 'with roles and collaborators' do subject do - create :project, - approved: true, - project_metadata_attributes: { - collaborators: 'Test', - external_funding_source: 'Tooth fairy', - sequencing_budget_cost_centre: '123', - funding_comments: 'It is funded', - project_manager: project_manager - } + create( + :project, + approved: true, + project_metadata_attributes: { + collaborators: 'Test', + external_funding_source: 'Tooth fairy', + sequencing_budget_cost_centre: '123', + funding_comments: 'It is funded', + project_manager: project_manager + } + ) end let(:project_manager) { create(:project_manager) } - let!(:manager) { create :manager, authorizable: subject } + let!(:manager) { create(:manager, authorizable: subject) } let(:metadata) { subject.project_metadata } diff --git a/spec/models/api/pulldown_multiplexed_library_tube_io_spec.rb b/spec/models/api/pulldown_multiplexed_library_tube_io_spec.rb index c3e5f3da70..da0514c418 100644 --- a/spec/models/api/pulldown_multiplexed_library_tube_io_spec.rb +++ b/spec/models/api/pulldown_multiplexed_library_tube_io_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' RSpec.describe Api::PulldownMultiplexedLibraryTubeIO do - subject { create :pulldown_multiplexed_library_tube, volume: 12.0, concentration: 8.0 } + subject { create(:pulldown_multiplexed_library_tube, volume: 12.0, concentration: 8.0) } let(:expected_json) do { diff --git a/spec/models/api/reference_genome_io_spec.rb b/spec/models/api/reference_genome_io_spec.rb index 58cb9823a5..90860b2c97 100644 --- a/spec/models/api/reference_genome_io_spec.rb +++ b/spec/models/api/reference_genome_io_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' RSpec.describe Api::ReferenceGenomeIO do - subject { create :reference_genome } + subject { create(:reference_genome) } let(:expected_json) { { 'uuid' => subject.uuid, 'internal_id' => subject.id } } diff --git a/spec/models/api/request_io_spec.rb b/spec/models/api/request_io_spec.rb index aa6e79d52b..5a2e7cd414 100644 --- a/spec/models/api/request_io_spec.rb +++ b/spec/models/api/request_io_spec.rb @@ -3,11 +3,11 @@ require 'rails_helper' RSpec.describe Api::RequestIO do - subject { create :request, asset: source_asset, target_asset: target_asset } + subject { create(:request, asset: source_asset, target_asset: target_asset) } context 'between tubes' do - let(:source_asset) { create :sample_tube } - let(:target_asset) { create :library_tube } + let(:source_asset) { create(:sample_tube) } + let(:target_asset) { create(:library_tube) } let(:expected_json) do { @@ -42,8 +42,8 @@ end context 'between wells' do - let(:source_asset) { create :untagged_well } - let(:target_asset) { create :untagged_well } + let(:source_asset) { create(:untagged_well) } + let(:target_asset) { create(:untagged_well) } let(:expected_json) do { @@ -74,7 +74,7 @@ end context 'with no target asset' do - let(:source_asset) { create :untagged_well } + let(:source_asset) { create(:untagged_well) } let(:target_asset) { nil } let(:expected_json) do @@ -98,7 +98,7 @@ end context 'with metadata' do - subject { create :library_creation_request } + subject { create(:library_creation_request) } let(:expected_json) do { diff --git a/spec/models/api/sample_io_spec.rb b/spec/models/api/sample_io_spec.rb index 1de1a755f1..adaee0b73e 100644 --- a/spec/models/api/sample_io_spec.rb +++ b/spec/models/api/sample_io_spec.rb @@ -4,71 +4,73 @@ RSpec.describe Api::SampleIO do subject do - create :sample, - name: 'sample_testing_messages', - component_samples: [comp_sample1, comp_sample2], - updated_by_manifest: true, - control: true, - control_type: 'positive', - sample_metadata_attributes: { - supplier_name: 'A name', - phenotype: 'positive', - gc_content: 'Neutral', - dna_source: 'Genomic', - volume: 'N/A', - sibling: '209_210', - is_resubmitted: true, - date_of_sample_collection: '02-Oct', - date_of_sample_extraction: '02-Oct', - sample_extraction_method: '5', - sample_purified: 'N', - purification_method: 'Other', - concentration: '100', - concentration_determined_by: 'Nanodrop', - sample_type: 'MDA', - sample_storage_conditions: '+4C', - genotype: 'WT', - age: '10 weeks', - cell_type: 'iPSC-derived microglia', - disease_state: 'Healthy', - compound: 'lomitapide', - dose: '10 uM', - immunoprecipitate: 'antiKdm1a, ab17721, 4ug/IP', - growth_condition: 'Oxford N2 media without geltrex', - organism_part: 'Primary T cells', - time_point: '2020-03-18', - disease: 'Tumour Growing', - subject: '19', - treatment: '10uM lomitapide in 0.1% ethanol', - date_of_consent_withdrawn: DateTime.new(2021, 3, 19, 13, 36, 51), - user_id_of_consent_withdrawn: user.id, - reference_genome_id: reference_genome.id, - organism: 'rat', - sample_ebi_accession_number: 18_374_739_430, - sample_common_name: 'mouse', - sample_description: 'desc', - sample_taxon_id: 2, - father: 'fred', - mother: 'frieda', - replicate: 'yes', - ethnicity: 'stuff', - gender: 'female', - cohort: 'this one', - country_of_origin: 'uk', - geographical_region: 'cambridge', - sample_public_name: 'public_name', - sample_sra_hold: 'Hold', - sample_strain_att: 'stuff about strain', - consent_withdrawn: false, - donor_id: 2, - developmental_stage: 'thing' - } + create( + :sample, + name: 'sample_testing_messages', + component_samples: [comp_sample1, comp_sample2], + updated_by_manifest: true, + control: true, + control_type: 'positive', + sample_metadata_attributes: { + supplier_name: 'A name', + phenotype: 'positive', + gc_content: 'Neutral', + dna_source: 'Genomic', + volume: 'N/A', + sibling: '209_210', + is_resubmitted: true, + date_of_sample_collection: '02-Oct', + date_of_sample_extraction: '02-Oct', + sample_extraction_method: '5', + sample_purified: 'N', + purification_method: 'Other', + concentration: '100', + concentration_determined_by: 'Nanodrop', + sample_type: 'MDA', + sample_storage_conditions: '+4C', + genotype: 'WT', + age: '10 weeks', + cell_type: 'iPSC-derived microglia', + disease_state: 'Healthy', + compound: 'lomitapide', + dose: '10 uM', + immunoprecipitate: 'antiKdm1a, ab17721, 4ug/IP', + growth_condition: 'Oxford N2 media without geltrex', + organism_part: 'Primary T cells', + time_point: '2020-03-18', + disease: 'Tumour Growing', + subject: '19', + treatment: '10uM lomitapide in 0.1% ethanol', + date_of_consent_withdrawn: DateTime.new(2021, 3, 19, 13, 36, 51), + user_id_of_consent_withdrawn: user.id, + reference_genome_id: reference_genome.id, + organism: 'rat', + sample_ebi_accession_number: 18_374_739_430, + sample_common_name: 'mouse', + sample_description: 'desc', + sample_taxon_id: 2, + father: 'fred', + mother: 'frieda', + replicate: 'yes', + ethnicity: 'stuff', + gender: 'female', + cohort: 'this one', + country_of_origin: 'uk', + geographical_region: 'cambridge', + sample_public_name: 'public_name', + sample_sra_hold: 'Hold', + sample_strain_att: 'stuff about strain', + consent_withdrawn: false, + donor_id: 2, + developmental_stage: 'thing' + } + ) end - let(:user) { create :user } - let(:reference_genome) { create :reference_genome } - let(:comp_sample1) { create :sample } - let(:comp_sample2) { create :sample } + let(:user) { create(:user) } + let(:reference_genome) { create(:reference_genome) } + let(:comp_sample1) { create(:sample) } + let(:comp_sample2) { create(:sample) } let(:expected_json) do { diff --git a/spec/models/api/sample_tube_io_spec.rb b/spec/models/api/sample_tube_io_spec.rb index b1f1210586..0ec24d4ee6 100644 --- a/spec/models/api/sample_tube_io_spec.rb +++ b/spec/models/api/sample_tube_io_spec.rb @@ -3,9 +3,9 @@ require 'rails_helper' RSpec.describe Api::SampleTubeIO do - subject { create :sample_tube, volume: 12.0, concentration: 8.0, sample: sample } + subject { create(:sample_tube, volume: 12.0, concentration: 8.0, sample: sample) } - let(:sample) { create :sample } + let(:sample) { create(:sample) } let(:expected_json) do { diff --git a/spec/models/api/study_io_spec.rb b/spec/models/api/study_io_spec.rb index db1188fd17..b77ea8e5e4 100644 --- a/spec/models/api/study_io_spec.rb +++ b/spec/models/api/study_io_spec.rb @@ -4,25 +4,27 @@ RSpec.describe Api::StudyIO do subject do - create :study, - ethically_approved: true, - study_metadata_attributes: { - faculty_sponsor: create(:faculty_sponsor, name: 'John Smith'), - data_release_strategy: 'open', - data_release_timing: 'standard', - reference_genome: reference_genome, - array_express_accession_number: 'AE111', - ega_policy_accession_number: 'EGA222', - ega_dac_accession_number: 'DAC333', - program: create(:program, name: 'General'), - contaminated_human_data_access_group: 'contaminated human data access group test' - } + create( + :study, + ethically_approved: true, + study_metadata_attributes: { + faculty_sponsor: create(:faculty_sponsor, name: 'John Smith'), + data_release_strategy: 'open', + data_release_timing: 'standard', + reference_genome: reference_genome, + array_express_accession_number: 'AE111', + ega_policy_accession_number: 'EGA222', + ega_dac_accession_number: 'DAC333', + program: create(:program, name: 'General'), + contaminated_human_data_access_group: 'contaminated human data access group test' + } + ) end - let(:reference_genome) { create :reference_genome } + let(:reference_genome) { create(:reference_genome) } - let!(:manager) { create :manager, authorizable: subject } - let!(:manager2) { create :manager, authorizable: subject } + let!(:manager) { create(:manager, authorizable: subject) } + let!(:manager2) { create(:manager, authorizable: subject) } let(:expected_json) do { diff --git a/spec/models/api/study_sample_io_spec.rb b/spec/models/api/study_sample_io_spec.rb index 0ed500c2ba..4b0e93039f 100644 --- a/spec/models/api/study_sample_io_spec.rb +++ b/spec/models/api/study_sample_io_spec.rb @@ -3,10 +3,10 @@ require 'rails_helper' RSpec.describe Api::StudySampleIO do - subject { create :study_sample, study: study, sample: sample } + subject { create(:study_sample, study:, sample:) } - let(:study) { create :study } - let(:sample) { create :sample } + let(:study) { create(:study) } + let(:sample) { create(:sample) } let(:expected_json) do { diff --git a/spec/models/api/submission_io_spec.rb b/spec/models/api/submission_io_spec.rb index 35577d4565..daa7f9604c 100644 --- a/spec/models/api/submission_io_spec.rb +++ b/spec/models/api/submission_io_spec.rb @@ -3,9 +3,9 @@ require 'rails_helper' RSpec.describe Api::SubmissionIO do - subject { create :submission, user: user } + subject { create(:submission, user:) } - let(:user) { create :user } + let(:user) { create(:user) } let(:expected_json) do { diff --git a/spec/models/api/tag_io_spec.rb b/spec/models/api/tag_io_spec.rb index e4e6672c47..e947c67a2b 100644 --- a/spec/models/api/tag_io_spec.rb +++ b/spec/models/api/tag_io_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' RSpec.describe Api::TagIO do - subject { create :tag } + subject { create(:tag) } let(:expected_json) do { diff --git a/spec/models/api/well_io_spec.rb b/spec/models/api/well_io_spec.rb index f581e945cb..e7a94624e7 100644 --- a/spec/models/api/well_io_spec.rb +++ b/spec/models/api/well_io_spec.rb @@ -6,12 +6,14 @@ context 'with one sample' do # As of the current records, the 'description' and 'asset_size' attributes can uniquely identify a map. subject do - create :well_with_sample_and_without_plate, - map: Map.find_by(description: 'A1', asset_size: plate.size), - plate: plate + create( + :well_with_sample_and_without_plate, + map: Map.find_by(description: 'A1', asset_size: plate.size), + plate: plate + ) end - let(:plate) { create :plate, barcode: 'SQPD-1' } + let(:plate) { create(:plate, barcode: 'SQPD-1') } let(:sample) { subject.samples.first } let(:expected_json) do @@ -43,13 +45,15 @@ context 'with multiple samples' do subject do # As of the current records, the 'description' and 'asset_size' attributes can uniquely identify a map. - create :well_with_sample_and_without_plate, - map: Map.find_by(description: 'A1', asset_size: plate.size), - plate: plate, - aliquot_count: 2 + create( + :well_with_sample_and_without_plate, + map: Map.find_by(description: 'A1', asset_size: plate.size), + plate: plate, + aliquot_count: 2 + ) end - let(:plate) { create :plate, barcode: 'SQPD-1' } + let(:plate) { create(:plate, barcode: 'SQPD-1') } let(:sample) { subject.samples.first } # We only send samples in the event we have just one diff --git a/spec/models/bait_library_type_spec.rb b/spec/models/bait_library_type_spec.rb index ea31b09a8c..2cc063f901 100644 --- a/spec/models/bait_library_type_spec.rb +++ b/spec/models/bait_library_type_spec.rb @@ -4,7 +4,7 @@ describe BaitLibraryType do context 'When a bait library exists' do - let(:bait_library) { create :bait_library } + let(:bait_library) { create(:bait_library) } it 'bait libraries have library types' do expect(bait_library.bait_library_type).to be_truthy @@ -23,8 +23,8 @@ end context 'A request with a bait library' do - let(:request_type) { create :request_type, name: 'Bait Pulldown', target_asset_type: nil } - let(:request) { create :isc_request } + let(:request_type) { create(:request_type, name: 'Bait Pulldown', target_asset_type: nil) } + let(:request) { create(:isc_request) } it 'have a bait library type' do expect(request.request_metadata.bait_library.bait_library_type).to be_truthy diff --git a/spec/models/barcode_spec.rb b/spec/models/barcode_spec.rb index dcebddbe3c..79afce5188 100644 --- a/spec/models/barcode_spec.rb +++ b/spec/models/barcode_spec.rb @@ -98,7 +98,7 @@ context 'Adding labware association' do let(:barcode_value) { 'DN12345U' } let(:barcode_format) { 'sanger_ean13' } - let(:barcode) { build :sanger_ean13, barcode: barcode_value, format: barcode_format } + let(:barcode) { build(:sanger_ean13, barcode: barcode_value, format: barcode_format) } before { barcode.save! } @@ -127,7 +127,7 @@ end context 'sanger_ean13' do - let(:barcode) { build :sanger_ean13, barcode: barcode_value, format: barcode_format } + let(:barcode) { build(:sanger_ean13, barcode: barcode_value, format: barcode_format) } let(:barcode_value) { 'DN12345U' } let(:number) { 12_345 } @@ -160,7 +160,7 @@ end context 'sanger_code39' do - let(:barcode) { build :sanger_code39, barcode: barcode_value, format: barcode_format } + let(:barcode) { build(:sanger_code39, barcode: barcode_value, format: barcode_format) } let(:barcode_value) { 'DN12345U' } let(:number) { 12_345 } @@ -193,7 +193,7 @@ end context 'sequencescape22' do - let(:barcode) { build :sequencescape22, barcode: barcode_value, format: barcode_format } + let(:barcode) { build(:sequencescape22, barcode: barcode_value, format: barcode_format) } let(:barcode_value) { 'SQPD-12345' } let(:barcode_format) { 'sequencescape22' } let(:number) { 12_345 } @@ -233,7 +233,7 @@ end context 'infinium' do - let(:barcode) { build :infinium, barcode: barcode_value, format: barcode_format } + let(:barcode) { build(:infinium, barcode: barcode_value, format: barcode_format) } let(:barcode_value) { 'WG0010602-DNA' } let(:barcode_format) { 'infinium' } @@ -261,7 +261,7 @@ end context 'fluidigm' do - let(:barcode) { build :fluidigm, barcode: barcode_value, format: barcode_format } + let(:barcode) { build(:fluidigm, barcode: barcode_value, format: barcode_format) } let(:barcode_value) { '1662051218' } let(:barcode_format) { 'fluidigm' } @@ -286,7 +286,7 @@ end context 'uk biocentre v3' do - let(:barcode) { build :external, barcode: barcode_value, format: barcode_format } + let(:barcode) { build(:external, barcode: barcode_value, format: barcode_format) } let(:barcode_value) { 'RNA12345' } let(:barcode_format) { 'uk_biocentre_v3' } @@ -315,7 +315,7 @@ end context 'external' do - let(:barcode) { build :external, barcode: barcode_value, format: barcode_format } + let(:barcode) { build(:external, barcode: barcode_value, format: barcode_format) } let(:barcode_value) { 'EXT_135432_D' } let(:barcode_format) { 'external' } @@ -335,7 +335,7 @@ end context 'external - odd format' do - let(:barcode) { build :external, barcode: barcode_value, format: barcode_format } + let(:barcode) { build(:external, barcode: barcode_value, format: barcode_format) } let(:barcode_value) { 'Q123RT12E45' } let(:barcode_format) { 'external' } @@ -356,7 +356,7 @@ end context 'foreign - CGAP format' do - let(:barcode) { build :cgap, barcode: barcode_value, format: barcode_format } + let(:barcode) { build(:cgap, barcode: barcode_value, format: barcode_format) } let(:barcode_value) { 'CGAP-ABC123' } let(:barcode_format) { 'cgap' } diff --git a/spec/models/batch_spec.rb b/spec/models/batch_spec.rb index 6ac7c0c5ba..2d11359cff 100644 --- a/spec/models/batch_spec.rb +++ b/spec/models/batch_spec.rb @@ -51,10 +51,10 @@ describe '::for_user' do subject(:batch_for_user) { described_class.for_user(query) } - let(:user) { create :user } - let!(:owned_batch) { create :batch, user: user } - let!(:assigned_batch) { create :batch, assignee: user } - let!(:other_batch) { create :batch } + let(:user) { create(:user) } + let!(:owned_batch) { create(:batch, user:) } + let!(:assigned_batch) { create(:batch, assignee: user) } + let!(:other_batch) { create(:batch) } context 'with a user' do let(:query) { user } @@ -79,8 +79,8 @@ describe '::add_dynamic_validations' do # Specific validator tests can be found in spec/validators - let(:pipeline) { create :pipeline, validator_class_name: 'TestPipelineValidator' } - let(:batch) { described_class.new pipeline: pipeline } + let(:pipeline) { create(:pipeline, validator_class_name: 'TestPipelineValidator') } + let(:batch) { described_class.new pipeline: } it 'fails validation when dynamic validations fail' do stub_const( diff --git a/spec/models/broadcast_event/helpers/external_subjects_spec.rb b/spec/models/broadcast_event/helpers/external_subjects_spec.rb index fe0a44598a..f2e1b1a340 100644 --- a/spec/models/broadcast_event/helpers/external_subjects_spec.rb +++ b/spec/models/broadcast_event/helpers/external_subjects_spec.rb @@ -3,7 +3,7 @@ RSpec.describe BroadcastEvent::Helpers::ExternalSubjects, :heron_events do let(:testing_event_class) { Class.new(BroadcastEvent) { include BroadcastEvent::Helpers::ExternalSubjects } } - let(:labware) { create :labware } + let(:labware) { create(:labware) } let(:sub1) do { role_type: 'sender', diff --git a/spec/models/broadcast_event/lab_event_spec.rb b/spec/models/broadcast_event/lab_event_spec.rb index 572d91c3bd..1f06d87ce6 100644 --- a/spec/models/broadcast_event/lab_event_spec.rb +++ b/spec/models/broadcast_event/lab_event_spec.rb @@ -11,24 +11,31 @@ let(:json) { JSON.parse(subject.to_json) } let(:eventful) { request } - let(:batch) { create :sequencing_batch } - let(:study) { create :study } + let(:batch) { create(:sequencing_batch) } + let(:study) { create(:study) } let!(:request) do - create :sequencing_request_with_assets, batch: batch, request_type: batch.pipeline.request_types.first, study: study + create( + :sequencing_request_with_assets, + batch: batch, + request_type: batch.pipeline.request_types.first, + study: study + ) end let(:sample) { request.asset.samples.first } let(:stock_asset) { request.asset.labware } let(:lab_event) do - create :lab_event, - description: 'Read 1 Lin/block/hyb/load', - descriptors: { - 'key_a' => 'value a', - 'key_b' => 'value b' - }, - eventful: eventful + create( + :lab_event, + description: 'Read 1 Lin/block/hyb/load', + descriptors: { + 'key_a' => 'value a', + 'key_b' => 'value b' + }, + eventful: eventful + ) end - let(:user) { create :user } + let(:user) { create(:user) } it 'generates json' do expect(json).not_to be_nil @@ -103,7 +110,7 @@ end context 'from a non-sequencing batch' do - let(:eventful) { create :batch } + let(:eventful) { create(:batch) } it 'includes the expected subjects' do expect(json.dig('event', 'subjects')).to match_unordered_json([]) diff --git a/spec/models/broadcast_event/plate_cherrypicked_spec.rb b/spec/models/broadcast_event/plate_cherrypicked_spec.rb index b28c9f4031..61e8a063a0 100644 --- a/spec/models/broadcast_event/plate_cherrypicked_spec.rb +++ b/spec/models/broadcast_event/plate_cherrypicked_spec.rb @@ -4,11 +4,11 @@ RSpec.describe BroadcastEvent::PlateCherrypicked, :broadcast_event, :heron_events do def subject_record(subject_type, role_type, friendly_name, uuid) - { role_type: role_type, subject_type: subject_type, friendly_name: friendly_name, uuid: uuid } + { role_type:, subject_type:, friendly_name:, uuid: } end let(:uuids) { Array.new(6) { SecureRandom.uuid } } - let(:destination_plate) { create :plate } + let(:destination_plate) { create(:plate) } let(:plate1) do subject_record('plate', BroadcastEvent::PlateCherrypicked::SOURCE_PLATES_ROLE_TYPE, '000001', uuids[0]) end diff --git a/spec/models/broadcast_event/pool_released_spec.rb b/spec/models/broadcast_event/pool_released_spec.rb index 8d2cf90a48..d383e3aac4 100644 --- a/spec/models/broadcast_event/pool_released_spec.rb +++ b/spec/models/broadcast_event/pool_released_spec.rb @@ -4,31 +4,35 @@ RSpec.describe BroadcastEvent::PoolReleased, :broadcast_event do let(:source_plate) do - pl = create :full_stock_plate - pl.wells.first.aliquots << (create :aliquot, sample: tube.samples.first) - pl.wells.last.aliquots << (create :aliquot, sample: tube.samples.last) + pl = create(:full_stock_plate) + pl.wells.first.aliquots << (create(:aliquot, sample: tube.samples.first)) + pl.wells.last.aliquots << (create(:aliquot, sample: tube.samples.last)) tube.ancestors << pl pl end - let(:tube) { create :multiplexed_library_tube, sample_count: 2, purpose: (create :illumina_htp_mx_tube_purpose) } + let(:tube) { create(:multiplexed_library_tube, sample_count: 2, purpose: create(:illumina_htp_mx_tube_purpose)) } - let(:submission) { create :library_submission } + let(:submission) { create(:library_submission) } let(:order) { submission.orders.first } let(:request1) do - create :multiplex_request, - asset: source_plate.wells.first, - target_asset: tube.receptacle, - state: 'passed', - order: order + create( + :multiplex_request, + asset: source_plate.wells.first, + target_asset: tube.receptacle, + state: 'passed', + order: order + ) end let(:request2) do - create :multiplex_request, - asset: source_plate.wells.last, - target_asset: tube.receptacle, - state: 'passed', - order: order + create( + :multiplex_request, + asset: source_plate.wells.last, + target_asset: tube.receptacle, + state: 'passed', + order: order + ) end - let(:library_request) { create :library_request, target_asset: source_plate.wells.first } + let(:library_request) { create(:library_request, target_asset: source_plate.wells.first) } let(:event) { described_class.create!(seed: tube, user: create(:user), properties: { order_id: order.id }) } let(:subject_hash) { event.as_json['event'][:subjects].group_by(&:role_type) } diff --git a/spec/models/broadcast_event/qc_assay_spec.rb b/spec/models/broadcast_event/qc_assay_spec.rb index a611892d5c..0e053805f8 100644 --- a/spec/models/broadcast_event/qc_assay_spec.rb +++ b/spec/models/broadcast_event/qc_assay_spec.rb @@ -17,9 +17,9 @@ let(:json) { JSON.parse(subject.to_json) } let(:lot_number) { '12345' } - let(:plate) { create :plate_with_untagged_wells, sample_count: 2, studies: [study], parents: [stock_plate] } - let(:stock_plate) { create :stock_plate, purpose: PlatePurpose.stock_plate_purpose, well_count: 2 } - let(:study) { create :study } + let(:plate) { create(:plate_with_untagged_wells, sample_count: 2, studies: [study], parents: [stock_plate]) } + let(:stock_plate) { create(:stock_plate, purpose: PlatePurpose.stock_plate_purpose, well_count: 2) } + let(:study) { create(:study) } let(:well1) { plate.wells[0] } let(:sample1) { well1.samples.first } let(:well2) { plate.wells[1] } @@ -27,12 +27,14 @@ context 'A single assay qc_assay' do let(:qc_assay) do - create :qc_assay, - lot_number: lot_number, - qc_results: [ - build(:qc_result_concentration, asset: well1, assay_type: 'Example Assay', assay_version: 'v0.0'), - build(:qc_result_concentration, asset: well2, assay_type: 'Example Assay', assay_version: 'v0.0') - ] + create( + :qc_assay, + lot_number: lot_number, + qc_results: [ + build(:qc_result_concentration, asset: well1, assay_type: 'Example Assay', assay_version: 'v0.0'), + build(:qc_result_concentration, asset: well2, assay_type: 'Example Assay', assay_version: 'v0.0') + ] + ) end describe '#to_json' do @@ -100,12 +102,14 @@ # The API supports multiple different assays types being conducted at the same time, # but event wise these should be distinguishable. let(:qc_assay) do - create :qc_assay, - lot_number: lot_number, - qc_results: [ - build(:qc_result_concentration, asset: well1, assay_type: 'Example Assay', assay_version: 'v0.0'), - build(:qc_result_concentration, asset: well2, assay_type: 'Other Assay', assay_version: 'v0.0') - ] + create( + :qc_assay, + lot_number: lot_number, + qc_results: [ + build(:qc_result_concentration, asset: well1, assay_type: 'Example Assay', assay_version: 'v0.0'), + build(:qc_result_concentration, asset: well2, assay_type: 'Other Assay', assay_version: 'v0.0') + ] + ) end describe '#to_json' do diff --git a/spec/models/broadcast_event/sequencing_complete_spec.rb b/spec/models/broadcast_event/sequencing_complete_spec.rb index b7e7690b1a..83f1ae9db4 100644 --- a/spec/models/broadcast_event/sequencing_complete_spec.rb +++ b/spec/models/broadcast_event/sequencing_complete_spec.rb @@ -7,7 +7,7 @@ let(:study) { create(:study) } let(:project) { create(:project) } let(:sample) { create(:sample) } - let(:aliquot) { create(:aliquot, study: study, project: project, sample: sample) } + let(:aliquot) { create(:aliquot, study:, project:, sample:) } let(:pipeline) { create(:pipeline) } let(:submission) { create(:submission_without_order, priority: 3) } let(:request_type) { create(:sequencing_request_type, product_line: create(:product_line)) } @@ -17,7 +17,7 @@ :sequencing_request_with_assets, project: nil, study: nil, - batch: create(:batch, pipeline: pipeline), + batch: create(:batch, pipeline:), request_type: request_type, submission: submission, target_asset: lane, diff --git a/spec/models/bulk_submission_spec.rb b/spec/models/bulk_submission_spec.rb index 6871bd386c..b222344c6c 100644 --- a/spec/models/bulk_submission_spec.rb +++ b/spec/models/bulk_submission_spec.rb @@ -6,7 +6,7 @@ subject { described_class.new(spreadsheet: submission_file, encoding: encoding) } let(:encoding) { 'Windows-1252' } - let(:spreadsheet_path) { Rails.root.join('features', 'submission', 'csv', spreadsheet_filename) } + let(:spreadsheet_path) { Rails.root.join('spec', 'data', 'submission', spreadsheet_filename) } # NB. fixture_file_upload is a Rails method on ActionDispatch::TestProcess::FixtureFile let(:submission_file) { fixture_file_upload(spreadsheet_path) } @@ -14,17 +14,17 @@ let(:number_submissions_created) { subject.completed_submissions.first.length } let(:generated_submissions) { Submission.find(subject.completed_submissions.first) } let(:generated_submission) { generated_submissions.first } - let(:request_types) { create_list :well_request_type, 2 } + let(:request_types) { create_list(:well_request_type, 2) } after { submission_file.close } - let!(:study) { create :study, name: 'abc123_study' } - let!(:asset_group) { create :asset_group, name: 'assetgroup123', study: study, asset_count: 2 } - let!(:library_type) { create :library_type, name: 'Standard' } + let!(:study) { create(:study, name: 'abc123_study') } + let!(:asset_group) { create(:asset_group, name: 'assetgroup123', study: study, asset_count: 2) } + let!(:library_type) { create(:library_type, name: 'Standard') } before do - create :user, login: 'user' - create :project, name: 'Test project' + create(:user, login: 'user') + create(:project, name: 'Test project') end context 'a simple submission' do @@ -65,7 +65,7 @@ context 'an asset driven submission' do let(:spreadsheet_filename) { 'template_for_bulk_submission.csv' } - let!(:asset) { create :plate, barcode: 'SQPD-1', well_count: 1, well_factory: :untagged_well } + let!(:asset) { create(:plate, barcode: 'SQPD-1', well_count: 1, well_factory: :untagged_well) } let(:submission_template_hash) do { name: 'Example Template', @@ -100,7 +100,7 @@ let(:spreadsheet_filename) { 'pcr_cycles.csv' } let!(:submission_template) do - create :limber_wgs_submission_template, name: 'pcr_cycle_test', request_types: [request_type] + create(:limber_wgs_submission_template, name: 'pcr_cycle_test', request_types: [request_type]) end let(:request_type) { create(:library_request_type) } @@ -129,10 +129,10 @@ context 'a submission with primer_panels' do let(:spreadsheet_filename) { 'primer_panels.csv' } - let!(:primer_panel) { create :primer_panel, name: 'Test panel' } + let!(:primer_panel) { create(:primer_panel, name: 'Test panel') } let!(:submission_template) do - create :limber_wgs_submission_template, name: 'primer_panel_test', request_types: [request_type] + create(:limber_wgs_submission_template, name: 'primer_panel_test', request_types: [request_type]) end let(:request_type) { create(:gbs_request_type) } @@ -162,11 +162,11 @@ context 'a submission with bait libraries' do let(:spreadsheet_filename) { '2_valid_sc_submissions.csv' } - let!(:bait_library) { create :bait_library, name: 'Bait library 1' } - let!(:bait_library_2) { create :bait_library, name: 'Bait library 2' } + let!(:bait_library) { create(:bait_library, name: 'Bait library 1') } + let!(:bait_library_2) { create(:bait_library, name: 'Bait library 2') } let!(:submission_template) do - create :limber_wgs_submission_template, name: 'Bait submission example', request_types: [request_type] + create(:limber_wgs_submission_template, name: 'Bait submission example', request_types: [request_type]) end let(:request_type) { create(:isc_library_request_type) } @@ -196,7 +196,7 @@ let(:spreadsheet_filename) { 'with_lowercase_library_type.csv' } let!(:submission_template) do - create :limber_wgs_submission_template, name: 'library_type_test', request_types: [request_type] + create(:limber_wgs_submission_template, name: 'library_type_test', request_types: [request_type]) end let(:request_type) { create(:library_request_type) } @@ -227,7 +227,7 @@ let(:spreadsheet_filename) { 'with_unknown_library_type.csv' } let!(:submission_template) do - create :limber_wgs_submission_template, name: 'library_type_test', request_types: [request_type] + create(:limber_wgs_submission_template, name: 'library_type_test', request_types: [request_type]) end let(:request_type) { create(:library_request_type) } @@ -243,4 +243,64 @@ ) end end + + context 'a submission with additional template name validations' do + context 'when valid for scRNA template' do + let(:submission_template_hash) do + { + name: 'Limber-Htp - scRNA Core cDNA Prep GEM-X 5p', + submission_class_name: 'LinearSubmission', + product_catalogue: 'Generic', + submission_parameters: { + request_options: { + }, + request_types: request_types.map(&:key) + } + } + end + let(:spreadsheet_filename) { 'scrna_additional_validations_valid.csv' } + + before { SubmissionSerializer.construct!(submission_template_hash) } + + it 'is valid' do + expect(subject).to be_valid + end + + it 'generates submissions when processed' do + subject.process + expect(number_submissions_created).to eq(2) + end + + it 'generates submissions with one order' do + subject.process + expect(generated_submission.orders.count).to eq(1) + end + end + + context 'when invalid for scRNA template' do + let(:submission_template_hash) do + { + name: 'Limber-Htp - scRNA Core cDNA Prep GEM-X 5p', + submission_class_name: 'LinearSubmission', + product_catalogue: 'Generic', + submission_parameters: { + request_options: { + }, + request_types: request_types.map(&:key) + } + } + end + let(:spreadsheet_filename) { 'scrna_additional_validations_invalid.csv' } + + before { SubmissionSerializer.construct!(submission_template_hash) } + + it 'raises an error and sets an error message' do + expect { subject.process }.to raise_error(ActiveRecord::RecordInvalid) + expect(subject.errors.messages[:spreadsheet][0]).to eq( + "Inconsistent values for column 'scRNA Core Number of Samples per Pool' for " \ + "Study name 'abc123_study', all rows for a specific study must have the same value" + ) + end + end + end end diff --git a/spec/models/cherrypick_request_spec.rb b/spec/models/cherrypick_request_spec.rb index 15d36961e2..aec200cd8d 100644 --- a/spec/models/cherrypick_request_spec.rb +++ b/spec/models/cherrypick_request_spec.rb @@ -4,10 +4,10 @@ require 'shared_contexts/limber_shared_context' describe CherrypickRequest do - let(:source_asset) { create :tagged_well } - let(:target_asset) { create :empty_well } + let(:source_asset) { create(:tagged_well) } + let(:target_asset) { create(:empty_well) } - before { create :cherrypick_request, asset: source_asset, target_asset: target_asset } + before { create(:cherrypick_request, asset: source_asset, target_asset: target_asset) } it 'transfers the contents of the source asset to the target asset' do expect(target_asset.aliquots.length).to eq(source_asset.aliquots.length) diff --git a/spec/models/cherrypick_task/control_locator_spec.rb b/spec/models/cherrypick_task/control_locator_spec.rb index d69cfe7dc5..37cd0645f1 100644 --- a/spec/models/cherrypick_task/control_locator_spec.rb +++ b/spec/models/cherrypick_task/control_locator_spec.rb @@ -3,14 +3,7 @@ require 'rails_helper' RSpec.describe CherrypickTask::ControlLocator do - let(:instance) do - described_class.new( - batch_id: batch_id, - total_wells: total_wells, - num_control_wells: num_control_wells, - wells_to_leave_free: wells_to_leave_free - ) - end + let(:instance) { described_class.new(batch_id:, total_wells:, num_control_wells:, wells_to_leave_free:) } shared_examples 'an invalid ControlLocator' do |plate_number, error = 'More controls than free wells'| it 'throws a "More controls than free wells" exception' do diff --git a/spec/models/comment_spec.rb b/spec/models/comment_spec.rb index 153ea85bee..922e4d6a37 100644 --- a/spec/models/comment_spec.rb +++ b/spec/models/comment_spec.rb @@ -18,43 +18,55 @@ end describe '#counts_for_requests' do - let(:request) { create :sequencing_request, asset: tube } - let(:tube) { create :multiplexed_library_tube } + context 'when request has asset' do + let(:request) { create(:sequencing_request, asset: tube) } + let(:tube) { create(:multiplexed_library_tube) } - before do - create :comment, commentable: tube, description: 'An excellent tube' - create :comment, commentable: tube.receptacle, description: 'A good receptacle' - create :comment, commentable: request, description: 'A reasonable request' + before do + create(:comment, commentable: tube, description: 'An excellent tube') + create(:comment, commentable: tube.receptacle, description: 'A good receptacle') + create(:comment, commentable: request, description: 'A reasonable request') + end + + it 'counts comments on requests, their assets and receptacles' do + expect(described_class.counts_for_requests([request])).to eq({ request.id => 3 }) + end end - it 'counts comments on requests, their assets and receptacles' do - expect(described_class.counts_for_requests([request])).to eq({ request.id => 3 }) + context 'when request has no asset' do + let(:request) { create(:sequencing_request) } + + before { create(:comment, commentable: request, description: 'A reasonable request') } + + it 'counts comments on requests only' do + expect(described_class.counts_for_requests([request])).to eq({ request.id => 1 }) + end end end context 'while adding comments to requests' do - let(:user) { create :user } - let(:study) { create :study } - let(:project) { create :project } + let(:user) { create(:user) } + let(:study) { create(:study) } + let(:project) { create(:project) } - let(:asset) { create :empty_sample_tube } + let(:asset) { create(:empty_sample_tube) } - let(:asset2) { create :empty_sample_tube } + let(:asset2) { create(:empty_sample_tube) } - let(:order1) { create :order_with_submission, study: study, assets: [asset], project: project } - let(:order2) { create :order, study: study, assets: [asset], project: project } - let(:order3) { create :order, study: study, assets: [asset2], project: project } - let(:order4) { create :order_with_submission, study: study, assets: [asset2], project: project } + let(:order1) { create(:order_with_submission, study: study, assets: [asset], project: project) } + let(:order2) { create(:order, study: study, assets: [asset], project: project) } + let(:order3) { create(:order, study: study, assets: [asset2], project: project) } + let(:order4) { create(:order_with_submission, study: study, assets: [asset2], project: project) } let(:submission) { order1.submission } let(:submission2) { order4.submission } - let!(:sequencing_request) { create :request_with_sequencing_request_type, submission: submission } - let!(:request) { create :request, order: order1, asset: asset, submission: submission } - let!(:request2) { create :request, order: order2, submission: submission } + let!(:sequencing_request) { create(:request_with_sequencing_request_type, submission:) } + let!(:request) { create(:request, order: order1, asset: asset, submission: submission) } + let!(:request2) { create(:request, order: order2, submission: submission) } - let!(:request3) { create :request, order: order4, submission: order4.submission } - let!(:sequencing_request2) { create :request_with_sequencing_request_type, submission: order4.submission } + let!(:request3) { create(:request, order: order4, submission: order4.submission) } + let!(:sequencing_request2) { create(:request_with_sequencing_request_type, submission: order4.submission) } before do asset.aliquots.create!(sample: create(:sample, studies: [study])) @@ -113,17 +125,17 @@ end context 'adding to a plate' do - let(:plate) { create :plate, well_count: 1 } - let(:submission) { create :submission } - let!(:request) { create :request, asset: plate.wells.first, submission: submission } + let(:plate) { create(:plate, well_count: 1) } + let(:submission) { create(:submission) } + let!(:request) { create(:request, asset: plate.wells.first, submission: submission) } it 'also adds to the request' do - create :comment, commentable: plate, description: 'Hello' + create(:comment, commentable: plate, description: 'Hello') expect(request.reload.comments.first.description).to eq('Hello') end it 'propagates titles' do - create :comment, commentable: plate, description: 'Hello', title: 'Test' + create(:comment, commentable: plate, description: 'Hello', title: 'Test') expect(request.reload.comments.first.title).to eq('Test') end end diff --git a/spec/models/external_release_event_spec.rb b/spec/models/external_release_event_spec.rb index df5c5645c6..8c40438f2a 100644 --- a/spec/models/external_release_event_spec.rb +++ b/spec/models/external_release_event_spec.rb @@ -6,22 +6,22 @@ describe '::create_for_asset!' do subject { described_class.create_for_asset!(asset, sendmail) } - let(:asset) { build :lane, aliquots: aliquots, external_release: true } - let(:aliquots) { [study_a, study_a, study_b].map { |s| build :aliquot, study: s } } + let(:asset) { build(:lane, aliquots: aliquots, external_release: true) } + let(:aliquots) { [study_a, study_a, study_b].map { |s| build(:aliquot, study: s) } } let(:expected_recipients) { [user_on_multiple_studies.email, user_on_single_study.email] } let(:expected_message) { 'Data to be released externally set true' } - let!(:user_without_mail) { create :manager, email: '', roles: [study_a_managers] } + let!(:user_without_mail) { create(:manager, email: '', roles: [study_a_managers]) } let!(:user_on_multiple_studies) do - create :manager, email: 'test@example.com', roles: [study_a_managers, study_b_managers] + create(:manager, email: 'test@example.com', roles: [study_a_managers, study_b_managers]) end - let!(:user_on_single_study) { create :manager, email: 'test2@example.com', roles: [study_b_managers] } + let!(:user_on_single_study) { create(:manager, email: 'test2@example.com', roles: [study_b_managers]) } - let(:study_a) { create :study } - let(:study_b) { create :study } + let(:study_a) { create(:study) } + let(:study_b) { create(:study) } - let(:study_a_managers) { create :manager_role, authorizable: study_a } - let(:study_b_managers) { create :manager_role, authorizable: study_b } + let(:study_a_managers) { create(:manager_role, authorizable: study_a) } + let(:study_b_managers) { create(:manager_role, authorizable: study_b) } context 'when sendmail is true' do let(:sendmail) { true } diff --git a/spec/models/flowcell_type_spec.rb b/spec/models/flowcell_type_spec.rb index d9baeb9090..8213cefee8 100644 --- a/spec/models/flowcell_type_spec.rb +++ b/spec/models/flowcell_type_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' RSpec.describe FlowcellType do - subject { described_class.new(name: name) } + subject { described_class.new(name:) } context 'without a name' do let(:name) { '' } @@ -18,7 +18,7 @@ end context 'with a shared name' do - before { create :flowcell_type, name: 'Shared' } + before { create(:flowcell_type, name: 'Shared') } let(:name) { 'Shared' } @@ -26,7 +26,7 @@ end context 'with a shared name (case-insensitive)' do - before { create :flowcell_type, name: 'Shared' } + before { create(:flowcell_type, name: 'Shared') } let(:name) { 'shared' } diff --git a/spec/models/illumina_htp/initial_stock_tube_purpose_spec.rb b/spec/models/illumina_htp/initial_stock_tube_purpose_spec.rb index 29dd463851..3cc164ce07 100644 --- a/spec/models/illumina_htp/initial_stock_tube_purpose_spec.rb +++ b/spec/models/illumina_htp/initial_stock_tube_purpose_spec.rb @@ -3,28 +3,28 @@ require 'rails_helper' describe IlluminaHtp::InitialStockTubePurpose do - let(:tube_purpose) { create :illumina_htp_initial_stock_tube_purpose } - let(:tube) { create :stock_multiplexed_library_tube, purpose: tube_purpose, name: 'Current Asset' } + let(:tube_purpose) { create(:illumina_htp_initial_stock_tube_purpose) } + let(:tube) { create(:stock_multiplexed_library_tube, purpose: tube_purpose, name: 'Current Asset') } describe '#sibling_tubes' do subject { tube_purpose.sibling_tubes(tube) } - let(:current_submission) { create :submission } + let(:current_submission) { create(:submission) } let(:parent_well) do - well = create :well + well = create(:well) well.stock_wells << well well end - let(:target_tube) { create :multiplexed_library_tube } + let(:target_tube) { create(:multiplexed_library_tube) } let(:sibling_state) { 'pending' } let(:library_request) do - create :multiplex_request, asset: parent_well, target_asset: target_tube, submission: current_submission + create(:multiplex_request, asset: parent_well, target_asset: target_tube, submission: current_submission) end before do - create :transfer_request, asset: parent_well, target_asset: tube, submission: current_submission + create(:transfer_request, asset: parent_well, target_asset: tube, submission: current_submission) library_request if sibling_tube create :transfer_request, @@ -33,15 +33,17 @@ submission: sibling_submission, state: sibling_state end - create :multiplex_request, - asset: parents_sibling_well, - target_asset: target_tube, - submission: sibling_submission, - request_type: sibling_request_type + create( + :multiplex_request, + asset: parents_sibling_well, + target_asset: target_tube, + submission: sibling_submission, + request_type: sibling_request_type + ) end context 'which has been created' do - let(:sibling_tube) { create :stock_multiplexed_library_tube, purpose: tube_purpose, name: 'Sibling tube' } + let(:sibling_tube) { create(:stock_multiplexed_library_tube, purpose: tube_purpose, name: 'Sibling tube') } let(:sibling_tube_hash) do { name: sibling_tube.name, @@ -54,7 +56,7 @@ context 'with siblings' do let(:sibling_request_type) { library_request.request_type } let(:sibling_submission) { current_submission } - let(:parents_sibling_well) { create :well } + let(:parents_sibling_well) { create(:well) } it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording expect(subject).to be_a Array @@ -65,9 +67,9 @@ # Not only is the request_type different, but so is the purpose, we also throw # an additional spanner in the works by adding another tube in upstream of the # sibling, which we don't want to show up. - let(:sibling_tube) { create :stock_multiplexed_library_tube, name: 'Sibling tube' } + let(:sibling_tube) { create(:stock_multiplexed_library_tube, name: 'Sibling tube') } let(:sibling_submission) { current_submission } - let(:sibling_request_type) { create :multiplex_request_type } + let(:sibling_request_type) { create(:multiplex_request_type) } let(:sibling_state) { 'started' } it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording @@ -83,10 +85,10 @@ # >-> MX # P -> P -> T context 'which have a lineage of siblings' do - let(:sibling_tube) { create :stock_multiplexed_library_tube, name: 'Sibling tube' } - let(:sibling_descendant) { create :stock_multiplexed_library_tube, name: 'Sibling tube descendant' } + let(:sibling_tube) { create(:stock_multiplexed_library_tube, name: 'Sibling tube') } + let(:sibling_descendant) { create(:stock_multiplexed_library_tube, name: 'Sibling tube descendant') } let(:sibling_submission) { current_submission } - let(:sibling_request_type) { create :multiplex_request_type } + let(:sibling_request_type) { create(:multiplex_request_type) } let(:sibling_state) { 'passed' } let(:sibling_descendant_hash) do { @@ -98,11 +100,13 @@ end before do - create :transfer_request, - asset: sibling_tube, - target_asset: sibling_descendant, - submission: sibling_submission, - state: 'passed' + create( + :transfer_request, + asset: sibling_tube, + target_asset: sibling_descendant, + submission: sibling_submission, + state: 'passed' + ) end it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording @@ -117,7 +121,7 @@ let(:sibling_request_type) { library_request.request_type } let(:sibling_submission) { current_submission } let(:sibling_tube) { create(:well) } - let(:parents_sibling_well) { create :well } + let(:parents_sibling_well) { create(:well) } it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording expect(subject).to be_a Array @@ -127,7 +131,7 @@ context 'with unrelated requests out the same well' do let(:sibling_request_type) { library_request.request_type } - let(:sibling_submission) { create :submission } + let(:sibling_submission) { create(:submission) } let(:parents_sibling_well) { parent_well } it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording @@ -164,7 +168,7 @@ context 'with siblings' do let(:sibling_request_type) { library_request.request_type } let(:sibling_submission) { current_submission } - let(:parents_sibling_well) { create :well } + let(:parents_sibling_well) { create(:well) } it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording expect(subject).to be_a Array diff --git a/spec/models/illumina_htp/requests/gbs_request_spec.rb b/spec/models/illumina_htp/requests/gbs_request_spec.rb index e50774cf6a..c82a11984d 100644 --- a/spec/models/illumina_htp/requests/gbs_request_spec.rb +++ b/spec/models/illumina_htp/requests/gbs_request_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' describe IlluminaHtp::Requests::GbsRequest do - subject(:request) { create :gbs_request } + subject(:request) { create(:gbs_request) } describe '#request_metadata' do describe '#primer_panel' do diff --git a/spec/models/illumina_htp/requests/heron_request_spec.rb b/spec/models/illumina_htp/requests/heron_request_spec.rb index 8f38925810..75613c22b9 100644 --- a/spec/models/illumina_htp/requests/heron_request_spec.rb +++ b/spec/models/illumina_htp/requests/heron_request_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' describe IlluminaHtp::Requests::HeronRequest, :heron do - subject(:request) { create :heron_request } + subject(:request) { create(:heron_request) } describe '#request_metadata' do describe '#primer_panel' do diff --git a/spec/models/illumina_htp/requests/heron_tailed_request_spec.rb b/spec/models/illumina_htp/requests/heron_tailed_request_spec.rb index 8cc8468612..8d72a51e64 100644 --- a/spec/models/illumina_htp/requests/heron_tailed_request_spec.rb +++ b/spec/models/illumina_htp/requests/heron_tailed_request_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' describe IlluminaHtp::Requests::HeronTailedRequest, :heron do - subject(:request) { build :heron_tailed_request } + subject(:request) { build(:heron_tailed_request) } describe '#request_metadata' do describe '#primer_panel' do diff --git a/spec/models/insdc/country_spec.rb b/spec/models/insdc/country_spec.rb index 33551a5f72..cbc979ab37 100644 --- a/spec/models/insdc/country_spec.rb +++ b/spec/models/insdc/country_spec.rb @@ -4,25 +4,25 @@ RSpec.describe Insdc::Country do context 'without a name' do - subject { build :insdc_country, name: nil } + subject { build(:insdc_country, name: nil) } it { is_expected.not_to be_valid } end context 'without a sort_priority' do - subject { build :insdc_country, sort_priority: nil } + subject { build(:insdc_country, sort_priority: nil) } it { is_expected.not_to be_valid } end context 'without a validation_state' do - subject { build :insdc_country, validation_state: nil } + subject { build(:insdc_country, validation_state: nil) } it { is_expected.not_to be_valid } end describe '#invalid!' do - let(:country) { build :insdc_country, validation_state: 'valid' } + let(:country) { build(:insdc_country, validation_state: 'valid') } it 'marks a country as invalid' do country.invalid! @@ -34,11 +34,11 @@ subject(:options) { described_class.options } before do - create :insdc_country, name: 'Excellent land' - create :insdc_country, name: 'Amazing land' - create :insdc_country, name: 'Best land' - create :insdc_country, :high_priority, name: 'Cool land' - create :insdc_country, :invalid, name: 'Dead land' + create(:insdc_country, name: 'Excellent land') + create(:insdc_country, name: 'Amazing land') + create(:insdc_country, name: 'Best land') + create(:insdc_country, :high_priority, name: 'Cool land') + create(:insdc_country, :invalid, name: 'Dead land') end it { is_expected.to be_an Array } diff --git a/spec/models/lab_event_spec.rb b/spec/models/lab_event_spec.rb index 9afb74540b..25d482b7bb 100644 --- a/spec/models/lab_event_spec.rb +++ b/spec/models/lab_event_spec.rb @@ -4,7 +4,7 @@ require 'broadcast_event/lab_event' RSpec.describe LabEvent do - subject { build :lab_event, user: build(:user) } + subject { build(:lab_event, user: build(:user)) } it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording expect(subject).to respond_to :eventful diff --git a/spec/models/labware_spec.rb b/spec/models/labware_spec.rb index 5db0d34af9..e5c4037999 100644 --- a/spec/models/labware_spec.rb +++ b/spec/models/labware_spec.rb @@ -73,7 +73,7 @@ describe '#labwhere_location' do subject { plate.labwhere_location } - let(:plate) { create :plate } + let(:plate) { create(:plate) } let(:parentage) { 'Sanger / Ogilvie / AA316' } let(:location) { 'Shelf 1' } @@ -96,8 +96,8 @@ describe '#labwhere_locations' do subject { described_class.labwhere_locations(barcodes) } - let(:plate_1) { create :plate } - let(:plate_2) { create :plate } + let(:plate_1) { create(:plate) } + let(:plate_2) { create(:plate) } let(:barcodes) { [plate_1.human_barcode, plate_2.human_barcode] } let(:parentage_1) { 'Sanger / Ogilvie / AA316' } let(:parentage_2) { 'Sanger / Ogilvie / AA317' } diff --git a/spec/models/lane_spec.rb b/spec/models/lane_spec.rb index 10cd5470d5..6e1eb633ce 100644 --- a/spec/models/lane_spec.rb +++ b/spec/models/lane_spec.rb @@ -3,8 +3,8 @@ require 'rails_helper' RSpec.describe Lane do - let(:lane) { create :lane_with_stock_plate } - let!(:request) { create :sequencing_request_with_assets, target_asset: lane } + let(:lane) { create(:lane_with_stock_plate) } + let!(:request) { create(:sequencing_request_with_assets, target_asset: lane) } it 'finds lanes that have requested aliquots' do aliquots = create_list(:aliquot, 5) @@ -15,8 +15,8 @@ lane.aliquots << aliquots # lanes containing requested aliquots - lane1 = create :lane - lane2 = create :lane + lane1 = create(:lane) + lane2 = create(:lane) lane1.aliquots << requested_aliquots.first lane2.aliquots << requested_aliquots.last lanes_to_be_found = [lane1, lane2] @@ -26,7 +26,7 @@ it 'can be rebroadcasted' do # request = create :sequencing_request, target_asset: lane - batch = create :sequencing_batch + batch = create(:sequencing_batch) batch.requests << request # as requests_as_targets is a scope, not the above instance of batch receive the message diff --git a/spec/models/library_type_spec.rb b/spec/models/library_type_spec.rb index b9fa5787e2..b04608ef9a 100644 --- a/spec/models/library_type_spec.rb +++ b/spec/models/library_type_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' RSpec.describe LibraryType do - subject { described_class.new(name: name) } + subject { described_class.new(name:) } context 'without a name' do let(:name) { '' } @@ -18,7 +18,7 @@ end context 'with a shared name' do - before { create :library_type, name: 'Shared' } + before { create(:library_type, name: 'Shared') } let(:name) { 'Shared' } @@ -26,7 +26,7 @@ end context 'with a shared name (case-insensitive)' do - before { create :library_type, name: 'Shared' } + before { create(:library_type, name: 'Shared') } let(:name) { 'shared' } @@ -35,9 +35,9 @@ describe '::alphabetical' do before do - create :library_type, name: 'Brilliant' - create :library_type, name: 'Amazing' - create :library_type, name: 'Cool' + create(:library_type, name: 'Brilliant') + create(:library_type, name: 'Amazing') + create(:library_type, name: 'Cool') end it 'returns library types in alphabetical order' do @@ -60,7 +60,7 @@ end before do - create :library_type, name: 'Not long read' + create(:library_type, name: 'Not long read') record_loader.create! end diff --git a/spec/models/linear_submission_spec.rb b/spec/models/linear_submission_spec.rb index 2a601dadf9..b5c62924bb 100644 --- a/spec/models/linear_submission_spec.rb +++ b/spec/models/linear_submission_spec.rb @@ -6,13 +6,13 @@ let(:mx_asset_count) { 5 } let(:sx_asset_count) { 5 } - let(:study) { create :study } - let(:project) { create :project } - let(:user) { create :user } + let(:study) { create(:study) } + let(:project) { create(:project) } + let(:user) { create(:user) } describe 'build (Submission factory)' do - let(:sequencing_request_type) { create :sequencing_request_type } - let(:purpose) { create :std_mx_tube_purpose } + let(:sequencing_request_type) { create(:sequencing_request_type) } + let(:purpose) { create(:std_mx_tube_purpose) } let(:request_options) do { 'read_length' => '108', 'fragment_size_required_from' => '150', 'fragment_size_required_to' => '200' } end @@ -20,19 +20,25 @@ context 'when a multiplexed submission' do describe 'Customer decision propagation' do let(:library_creation_request_type) do - create :well_request_type, :with_library_types, target_purpose: purpose, for_multiplexing: true + create(:well_request_type, :with_library_types, target_purpose: purpose, for_multiplexing: true) end - let(:product_criteria) { create :product_criteria } - let(:current_report) { create :qc_report, product_criteria: product_criteria } - let(:stock_well) { create :well } + let(:product_criteria) { create(:product_criteria) } + let(:current_report) { create(:qc_report, product_criteria:) } + let(:stock_well) { create(:well) } let(:request_well) do - well = create :well + well = create(:well) well.stock_wells.attach!([stock_well]) well.reload well end let(:expected_metric) do - create :qc_metric, asset: stock_well, qc_report: current_report, qc_decision: 'manually_failed', proceed: true + create( + :qc_metric, + asset: stock_well, + qc_report: current_report, + qc_decision: 'manually_failed', + proceed: true + ) end let(:mpx_submission) do create( @@ -68,7 +74,7 @@ context 'with basic behaviour' do let(:mpx_assets) { create_list(:sample_tube, mx_asset_count) } let(:library_creation_request_type) do - create :multiplexed_library_creation_request_type, target_purpose: purpose + create(:multiplexed_library_creation_request_type, target_purpose: purpose) end let(:mpx_submission) do create( @@ -107,7 +113,7 @@ end context 'when multiple requests after plexing' do - let(:sequencing_request_type_2) { create :sequencing_request_type } + let(:sequencing_request_type_2) { create(:sequencing_request_type) } let(:request_type_option) do [library_creation_request_type.id, sequencing_request_type_2.id, sequencing_request_type.id] end @@ -126,9 +132,9 @@ end context 'with two stages of library creation' do - let(:library_creation_stage1) { create :library_request_type, :with_library_types } - let(:library_creation_stage2) { create :library_request_type, :with_library_types } - let(:mx_request_type) { create :multiplex_request_type } + let(:library_creation_stage1) { create(:library_request_type, :with_library_types) } + let(:library_creation_stage2) { create(:library_request_type, :with_library_types) } + let(:mx_request_type) { create(:multiplex_request_type) } let(:request_type_option) do [library_creation_stage1.id, library_creation_stage2.id, mx_request_type.id, sequencing_request_type.id] end @@ -155,7 +161,7 @@ context 'when a single-plex submission' do let(:assets) { (1..sx_asset_count).map { |i| create(:sample_tube, name: "Asset#{i}") } } - let(:library_creation_request_type) { create :library_creation_request_type, :with_library_types } + let(:library_creation_request_type) { create(:library_creation_request_type, :with_library_types) } let(:request_type_option) { [library_creation_request_type.id, sequencing_request_type.id] } let(:submission) do create( @@ -225,33 +231,39 @@ end context 'when we have a multiplier for request type' do - let(:assets) { create_list :sample_tube, 2 } + let(:assets) { create_list(:sample_tube, 2) } let(:mx_request_type) do - create :multiplexed_library_creation_request_type, - asset_type: 'SampleTube', - target_asset_type: 'LibraryTube', - initial_state: 'pending', - name: 'Multiplexed Library Creation', - order: 1, - key: 'multiplexed_library_creation' + create( + :multiplexed_library_creation_request_type, + asset_type: 'SampleTube', + target_asset_type: 'LibraryTube', + initial_state: 'pending', + name: 'Multiplexed Library Creation', + order: 1, + key: 'multiplexed_library_creation' + ) end let(:lib_request_type) do - create :library_creation_request_type, - :with_library_types, - asset_type: 'SampleTube', - target_asset_type: 'LibraryTube', - initial_state: 'pending', - name: 'Library Creation', - order: 1, - key: 'library_creation' + create( + :library_creation_request_type, + :with_library_types, + asset_type: 'SampleTube', + target_asset_type: 'LibraryTube', + initial_state: 'pending', + name: 'Library Creation', + order: 1, + key: 'library_creation' + ) end let(:sequencing_request_type) do - create :request_type, - asset_type: 'LibraryTube', - initial_state: 'pending', - name: 'PE sequencing', - order: 2, - key: 'pe_sequencing' + create( + :request_type, + asset_type: 'LibraryTube', + initial_state: 'pending', + name: 'PE sequencing', + order: 2, + key: 'pe_sequencing' + ) end context 'when a multiplication factor of 5 is provided' do diff --git a/spec/models/location_report_form_spec.rb b/spec/models/location_report_form_spec.rb index 830e90742a..191dc3955f 100644 --- a/spec/models/location_report_form_spec.rb +++ b/spec/models/location_report_form_spec.rb @@ -44,15 +44,15 @@ let(:location_report_form) do build( :location_report_form, - report_type: report_type, - name: name, - location_barcode: location_barcode, - faculty_sponsor_ids: faculty_sponsor_ids, - study_id: study_id, - start_date: start_date, - end_date: end_date, - plate_purpose_ids: plate_purpose_ids, - barcodes_text: barcodes_text + report_type:, + name:, + location_barcode:, + faculty_sponsor_ids:, + study_id:, + start_date:, + end_date:, + plate_purpose_ids:, + barcodes_text: ) end let(:report_type) { nil } diff --git a/spec/models/location_report_spec.rb b/spec/models/location_report_spec.rb index e1911820a7..7b6a76b644 100644 --- a/spec/models/location_report_spec.rb +++ b/spec/models/location_report_spec.rb @@ -13,7 +13,7 @@ let(:study_2) { studies[1] } let(:study_1_sponsor) { study_1.study_metadata.faculty_sponsor } let(:study_2_sponsor) { study_2.study_metadata.faculty_sponsor } - let(:user) { create :user, login: 'test' } + let(:user) { create(:user, login: 'test') } # setup plates let(:plate_1) do @@ -25,16 +25,20 @@ ) end let!(:plt_1_asset_audit) do - create :asset_audit, - asset: plate_1, - created_at: Time.zone.parse('June 15, 2020 15:41'), - key: 'slf_receive_plates', - message: "Process '...' performed on instrument Reception fridge" - create :asset_audit, - asset: plate_1, - created_at: Time.zone.parse('June 16, 2020 15:42'), - key: 'slf_receive_plates', - message: "Process '...' performed on instrument Reception fridge" + create( + :asset_audit, + asset: plate_1, + created_at: Time.zone.parse('June 15, 2020 15:41'), + key: 'slf_receive_plates', + message: "Process '...' performed on instrument Reception fridge" + ) + create( + :asset_audit, + asset: plate_1, + created_at: Time.zone.parse('June 16, 2020 15:42'), + key: 'slf_receive_plates', + message: "Process '...' performed on instrument Reception fridge" + ) # return the last audit only end let(:plt_1_purpose) { plate_1.plate_purpose.name } @@ -44,12 +48,14 @@ # add retention instruction metadata to plate 1 custom metadatum collection let(:retention_key) { 'retention_instruction' } let(:retention_value) { 'Long term storage' } - let(:plate_1_custom_metadatum_collection) { create :custom_metadatum_collection, asset: plate_1, user: user } + let(:plate_1_custom_metadatum_collection) { create(:custom_metadatum_collection, asset: plate_1, user: user) } let(:plate_1_custom_metadatum) do - create :custom_metadatum, - custom_metadatum_collection: plate_1_custom_metadatum_collection, - key: retention_key, - value: retention_value + create( + :custom_metadatum, + custom_metadatum_collection: plate_1_custom_metadatum_collection, + key: retention_key, + value: retention_value + ) end let(:plate_2) do @@ -78,12 +84,14 @@ let(:plt_3_received_date) { 'Unknown' } # add retention instruction metadata to plate 3 custom metadatum collection - let(:plate_3_custom_metadatum_collection) { create :custom_metadatum_collection, asset: plate_3, user: user } + let(:plate_3_custom_metadatum_collection) { create(:custom_metadatum_collection, asset: plate_3, user: user) } let(:plate_3_custom_metadatum) do - create :custom_metadatum, - custom_metadatum_collection: plate_3_custom_metadatum_collection, - key: retention_key, - value: retention_value + create( + :custom_metadatum, + custom_metadatum_collection: plate_3_custom_metadatum_collection, + key: retention_key, + value: retention_value + ) end let(:headers_line) do @@ -107,15 +115,15 @@ let(:location_report) do build( :location_report, - report_type: report_type, - name: name, - location_barcode: location_barcode, - faculty_sponsor_ids: faculty_sponsor_ids, - study_id: study_id, - start_date: start_date, - end_date: end_date, - plate_purpose_ids: plate_purpose_ids, - barcodes: barcodes + report_type:, + name:, + location_barcode:, + faculty_sponsor_ids:, + study_id:, + start_date:, + end_date:, + plate_purpose_ids:, + barcodes: ) end let(:report_type) { nil } @@ -239,11 +247,7 @@ [plate_2.machine_barcode.to_s, 'Shelf 2', locn_prefix], [plate_3.machine_barcode.to_s, 'Shelf 3', locn_prefix] ].each do |lw_barcode, lw_locn_name, lw_locn_parentage| - stub_lwclient_labware_find_by_bc( - lw_barcode: lw_barcode, - lw_locn_name: lw_locn_name, - lw_locn_parentage: lw_locn_parentage - ) + stub_lwclient_labware_find_by_bc(lw_barcode:, lw_locn_name:, lw_locn_parentage:) end plate_1_custom_metadatum diff --git a/spec/models/lot_type_spec.rb b/spec/models/lot_type_spec.rb index d2a76a4121..cf144b5e69 100644 --- a/spec/models/lot_type_spec.rb +++ b/spec/models/lot_type_spec.rb @@ -5,7 +5,7 @@ RSpec.describe LotType do context 'validating' do - before { create :lot } + before { create(:lot) } it { is_expected.to validate_uniqueness_of(:name).case_insensitive } end @@ -18,8 +18,8 @@ end describe '#lot' do - let(:lot_type) { create :lot_type } - let(:user) { create :user } + let(:lot_type) { create(:lot_type) } + let(:user) { create(:user) } let(:template) { PlateTemplate.new } let(:lot) { lot_type.create!(template: template, user: user, lot_number: '123456789', received_at: '2014-02-01') } diff --git a/spec/models/orders/automated_order_spec.rb b/spec/models/orders/automated_order_spec.rb index 667fd020a2..478dd62b83 100644 --- a/spec/models/orders/automated_order_spec.rb +++ b/spec/models/orders/automated_order_spec.rb @@ -4,17 +4,17 @@ require_relative 'shared_order_specs' RSpec.describe AutomatedOrder do - subject { build :automated_order, assets: assets } + subject { build(:automated_order, assets:) } let(:assets) { [tube] } - let(:tube) { create :multiplexed_library_tube, aliquots: aliquots } - let(:study) { create :study } - let(:project) { create :project } + let(:tube) { create(:multiplexed_library_tube, aliquots:) } + let(:study) { create(:study) } + let(:project) { create(:project) } it_behaves_like 'an automated order' context 'with a cross study/project tube' do - let(:aliquots) { create_list :tagged_aliquot, 2 } + let(:aliquots) { create_list(:tagged_aliquot, 2) } it { is_expected.to be_valid } end diff --git a/spec/models/orders/order_spec.rb b/spec/models/orders/order_spec.rb index f9962ff643..91dca21504 100644 --- a/spec/models/orders/order_spec.rb +++ b/spec/models/orders/order_spec.rb @@ -4,10 +4,10 @@ require_relative 'shared_order_specs' RSpec.describe Order do - let(:study) { create :study, state: study_state } + let(:study) { create(:study, state: study_state) } let(:study_state) { 'pending' } - let(:project) { create :project } - let(:asset) { create :empty_sample_tube } + let(:project) { create(:project) } + let(:asset) { create(:empty_sample_tube) } describe 'study and project autodetection' do # When automating submission creation, it is really useful if we can @@ -16,16 +16,18 @@ # specify a study. subject(:order) do - build :order, - assets: assets, - autodetect_studies: autodetect_studies, - autodetect_projects: autodetect_projects, - study: nil, - project: nil + build( + :order, + assets: assets, + autodetect_studies: autodetect_studies, + autodetect_projects: autodetect_projects, + study: nil, + project: nil + ) end let(:assets) { [tube] } - let(:tube) { create :sample_tube, aliquots: aliquots } + let(:tube) { create(:sample_tube, aliquots:) } let(:study_state) { 'active' } context 'with autodetection turned on' do @@ -35,7 +37,7 @@ it_behaves_like 'an automated order' context 'with a cross study/project tube' do - let(:aliquots) { create_list :tagged_aliquot, 2 } + let(:aliquots) { create_list(:tagged_aliquot, 2) } # We may wish to relax this in future. I'm keeping the restriction in # place for the time being solely because we don't need the @@ -48,7 +50,7 @@ context 'with autodetection turned off' do let(:autodetect_studies) { false } let(:autodetect_projects) { false } - let(:aliquots) { create_list :tagged_aliquot, 2, study: study, project: project } + let(:aliquots) { create_list(:tagged_aliquot, 2, study:, project:) } it { is_expected.not_to be_valid } end @@ -56,15 +58,15 @@ context 'An order' do let(:shared_template) { 'shared_template' } - let(:asset_a) { create :sample_tube } - let(:order) { create :order, assets: [asset_a], template_name: shared_template } + let(:asset_a) { create(:sample_tube) } + let(:order) { create(:order, assets: [asset_a], template_name: shared_template) } it 'not detect duplicates when there are none' do expect(order.duplicates_within(1.month)).not_to be_truthy end context 'with the same asset in a different order' do - before { create :order, assets: [asset_a], template_name: 'other_template' } + before { create(:order, assets: [asset_a], template_name: 'other_template') } it 'not detect duplicates' do expect(order.duplicates_within(1.month)).not_to be_truthy @@ -73,10 +75,10 @@ context 'with the same sample in a similar order' do before do - @asset_b = create :sample_tube, sample: asset_a.samples.first - @secondary_submission = create :submission + @asset_b = create(:sample_tube, sample: asset_a.samples.first) + @secondary_submission = create(:submission) @secondary_order = - create :order, assets: [@asset_b], template_name: shared_template, submission: @secondary_submission + create(:order, assets: [@asset_b], template_name: shared_template, submission: @secondary_submission) end it 'detect duplicates' do @@ -104,7 +106,7 @@ %w[SequencingRequest].each do |request_class| context "with #{request_class}" do before do - @sequencing_request_type = create :request_type, request_class_name: request_class + @sequencing_request_type = create(:request_type, request_class_name: request_class) order.request_types << @sequencing_request_type.id end @@ -116,30 +118,30 @@ end it 'order should not be valid if study is not active' do - order = build :order, study: study, assets: [asset.receptacle], project: project + order = build(:order, study: study, assets: [asset.receptacle], project: project) expect(order).not_to be_valid end it 'order should be valid if study is active on create' do study.activate! - order = create :order, study: study, assets: [asset.receptacle], project: project + order = create(:order, study: study, assets: [asset.receptacle], project: project) assert order.valid? study.deactivate! - new_asset = create :empty_sample_tube + new_asset = create(:empty_sample_tube) order.assets << new_asset assert order.valid? end it 'knows if it has samples that can not be included in submission' do - sample_manifest = create :tube_sample_manifest_with_samples - order = create :order, assets: sample_manifest.labware + sample_manifest = create(:tube_sample_manifest_with_samples) + order = create(:order, assets: sample_manifest.labware) expect(order.not_ready_samples.count).to eq 5 sample = sample_manifest.samples.first sample.sample_metadata.update(supplier_name: 'new_name') expect(order.reload.not_ready_samples.count).to eq 4 - sample_tube_without_manifest = create_list :sample_tube, 1 - order = create :order, assets: sample_tube_without_manifest + sample_tube_without_manifest = create_list(:sample_tube, 1) + order = create(:order, assets: sample_tube_without_manifest) expect(order.all_samples).not_to be_empty expect(order.not_ready_samples).to be_empty end diff --git a/spec/models/orders/shared_order_specs.rb b/spec/models/orders/shared_order_specs.rb index 3abe93fbe6..4a7efd96e9 100644 --- a/spec/models/orders/shared_order_specs.rb +++ b/spec/models/orders/shared_order_specs.rb @@ -2,7 +2,7 @@ shared_examples 'an automated order' do context 'with a cross study/project tube' do - let(:aliquots) { create_list :tagged_aliquot, 2 } + let(:aliquots) { create_list(:tagged_aliquot, 2) } it 'does not set study' do subject.valid? @@ -16,7 +16,7 @@ end context 'with a single study/project tube' do - let(:aliquots) { create_list :tagged_aliquot, 2, study: study, project: project } + let(:aliquots) { create_list(:tagged_aliquot, 2, study:, project:) } it { is_expected.to be_valid } @@ -32,8 +32,8 @@ context 'with two single study/project assets in different studies' do let(:assets) { [tube, other_tube] } - let(:other_tube) { create :multiplexed_library_tube, aliquots: other_aliquots } - let(:other_aliquots) { create_list :tagged_aliquot, 1 } + let(:other_tube) { create(:multiplexed_library_tube, aliquots: other_aliquots) } + let(:other_aliquots) { create_list(:tagged_aliquot, 1) } it { is_expected.not_to be_valid } end diff --git a/spec/models/parsers/cardinal_pbmc_count_parser_spec.rb b/spec/models/parsers/pbmc_count_parser_spec.rb similarity index 62% rename from spec/models/parsers/cardinal_pbmc_count_parser_spec.rb rename to spec/models/parsers/pbmc_count_parser_spec.rb index a4f0c2988c..24222a49ec 100644 --- a/spec/models/parsers/cardinal_pbmc_count_parser_spec.rb +++ b/spec/models/parsers/pbmc_count_parser_spec.rb @@ -19,117 +19,122 @@ def read_file(filename) File.read(filename) end -RSpec.describe Parsers::CardinalPbmcCountParser do - it 'will have an assay type' do - expect(described_class.assay_type).to eq('Cardinal_PBMC_Count') +RSpec.describe Parsers::PbmcCountParser do + it 'has an assay type' do + expect(described_class.assay_type).to eq('PBMC_Count') end - it 'will have an assay version' do + it 'has an assay version' do expect(described_class.assay_version).to eq('v1.0') end context 'when a file is parsed' do - let(:filename) { Rails.root.join('spec/data/parsers/cardinal_pbmc_count.csv') } + let(:filename) { Rails.root.join('spec/data/parsers/pbmc_count.csv') } let(:content) { read_file(filename) } let(:csv) { CSV.parse(content) } let(:parser) { described_class.new(csv) } - it 'will return the correct parser' do - expect(Parsers.parser_for('cardinal_pbmc_count.csv', nil, content)).to be_a(described_class) + it 'returns the correct parser' do + expect(Parsers.parser_for('pbmc_count.csv', nil, content)).to be_a(described_class) end - it 'will have some content' do + it 'has some content' do expect(parser.content).to eq(csv) end context 'when parsing rows' do let(:rows) { parser.rows } - it 'will have the correct number of rows' do + it 'has the correct number of rows' do expect(rows.length).to eq(8) end - it 'will have the correct csv for well A1' do + it 'has the correct csv for well A1' do row = rows[0] expect(row[0]).to eq('DN871908M:A1') expect(row[2]).to eq('2030000') expect(row[4]).to eq('75.00%') + expect(row[9]).to eq('2710000') end - it 'will have the correct csv for well H1' do + it 'has the correct csv for well H1' do row = rows[7] expect(row[0]).to eq('DN871908M:H1') expect(row[2]).to eq('1940000') expect(row[4]).to eq('74.00%') + expect(row[9]).to eq('2610000') end end context 'when formatting into qc data' do let(:qc_data) { parser.qc_data } - it 'will have the correct number of values' do + it 'has the correct number of values' do expect(qc_data.values.length).to eq(8) end - it 'will have the correct data for well A1' do + it 'has the correct data for well A1' do row = qc_data['A1'] expect(row[:live_cell_count]).to eq(Unit.new('2030000', 'cells')) expect(row[:viability]).to eq(Unit.new('75.00', '%')) + expect(row[:total_cell_count]).to eq(Unit.new('2710000', 'cells')) end - it 'will have the correct data for well H1' do + it 'has the correct data for well H1' do row = qc_data['H1'] expect(row[:live_cell_count]).to eq(Unit.new('1940000', 'cells')) expect(row[:viability]).to eq(Unit.new('74.00', '%')) + expect(row[:total_cell_count]).to eq(Unit.new('2610000', 'cells')) end end end context 'when the file has blank rows' do # this file has 1 row and 23 blank rows - let(:filename) { Rails.root.join('spec/data/parsers/cardinal_pbmc_count_blank_rows.csv') } + let(:filename) { Rails.root.join('spec/data/parsers/pbmc_count_blank_rows.csv') } let(:content) { read_file(filename) } let(:csv) { CSV.parse(content) } let(:parser) { described_class.new(csv) } - it 'will return the correct parser' do - expect(Parsers.parser_for('cardinal_pbmc_count.csv', nil, content)).to be_a(described_class) + it 'has the correct parser' do + expect(Parsers.parser_for('pbmc_count.csv', nil, content)).to be_a(described_class) end - it 'will have some content' do + it 'has some content' do expect(parser.content).to eq(csv) end - it 'will have some qc data' do + it 'has some qc data' do expect(parser.qc_data.values.length).to eq(1) end end context 'when a row has no cells' do # this file has 1 normal row, and a couple of rows with 0 live cells, and NaN viability - let(:filename) { Rails.root.join('spec/data/parsers/cardinal_pbmc_count_no_cells.csv') } + let(:filename) { Rails.root.join('spec/data/parsers/pbmc_count_no_cells.csv') } let(:content) { read_file(filename) } let(:csv) { CSV.parse(content) } let(:parser) { described_class.new(csv) } - it 'will have three qc data entries - one for each row in the file' do + it 'has three qc data entries - one for each row in the file' do expect(parser.qc_data.values.length).to eq(3) end - it 'will have cell count and viability metrics for the normal row' do - expect(parser.qc_data['A4'].keys).to eq(%i[live_cell_count viability]) + it 'has cell count and viability metrics for the normal row' do + expect(parser.qc_data['A4'].keys).to eq(%i[live_cell_count total_cell_count viability]) end - it 'will have just cell count for the rows with 0 cells' do - expect(parser.qc_data['A5'].keys).to eq([:live_cell_count]) - expect(parser.qc_data['E5'].keys).to eq([:live_cell_count]) + it 'has just cell count for the rows with 0 cells' do + expect(parser.qc_data['A5'].keys).to eq(%i[live_cell_count total_cell_count]) + expect(parser.qc_data['E5'].keys).to eq(%i[live_cell_count total_cell_count]) expect(parser.qc_data['E5'][:live_cell_count].zero?).to be(true) + expect(parser.qc_data['E5'][:total_cell_count].zero?).to be(true) end end context 'when updating qc results' do let(:plate) { create(:plate_with_empty_wells, well_count: 96) } - let(:filename) { Rails.root.join('spec/data/parsers/cardinal_pbmc_count.csv') } + let(:filename) { Rails.root.join('spec/data/parsers/pbmc_count.csv') } let(:content) { read_file(filename) } let(:csv) { CSV.parse(content) } let(:parser) { described_class.new(csv) } @@ -137,11 +142,11 @@ def read_file(filename) context 'when creating some qc results' do before { plate.update_qc_values_with_parser(parser) } - it 'will have the correct number of results' do - expect(QcResult.count).to eq(16) + it 'has the correct number of results' do + expect(QcResult.count).to eq(24) end - it 'will create the qc results for well A1' do + it 'has the qc results for well A1' do well = plate.wells.located_at('A1').first qc_results = QcResult.where(asset_id: well.id) @@ -149,18 +154,25 @@ def read_file(filename) expect(qc_result.value).to eq('75') expect(qc_result.units).to eq('%') - expect(qc_result.assay_type).to eq('Cardinal_PBMC_Count') + expect(qc_result.assay_type).to eq('PBMC_Count') expect(qc_result.assay_version).to eq('v1.0') qc_result = qc_results.find_by(key: 'live_cell_count') expect(qc_result.value).to eq('2030000') expect(qc_result.units).to eq('cells/ml') - expect(qc_result.assay_type).to eq('Cardinal_PBMC_Count') + expect(qc_result.assay_type).to eq('PBMC_Count') + expect(qc_result.assay_version).to eq('v1.0') + + qc_result = qc_results.find_by(key: 'total_cell_count') + + expect(qc_result.value).to eq('2710000') + expect(qc_result.units).to eq('cells/ml') + expect(qc_result.assay_type).to eq('PBMC_Count') expect(qc_result.assay_version).to eq('v1.0') end - it 'will create the qc results for well H1' do + it 'creates the qc results for well H1' do well = plate.wells.located_at('H1').first qc_results = QcResult.where(asset_id: well.id) @@ -173,6 +185,11 @@ def read_file(filename) expect(qc_result.value).to eq('1940000') expect(qc_result.units).to eq('cells/ml') + + qc_result = qc_results.find_by(key: 'total_cell_count') + + expect(qc_result.value).to eq('2610000') + expect(qc_result.units).to eq('cells/ml') end end end diff --git a/spec/models/phi_x/spiked_buffer_spec.rb b/spec/models/phi_x/spiked_buffer_spec.rb index 260178d970..2f52a80f50 100644 --- a/spec/models/phi_x/spiked_buffer_spec.rb +++ b/spec/models/phi_x/spiked_buffer_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' RSpec.describe PhiX::SpikedBuffer, :phi_x do - subject { build :phi_x_spiked_buffer, custom_options } + subject { build(:phi_x_spiked_buffer, custom_options) } context 'with suitable options' do let(:custom_options) { {} } # Fallback to factory defaults @@ -46,7 +46,7 @@ end context 'with a non-PhiX containing parent' do - let(:parent) { create :library_tube } + let(:parent) { create(:library_tube) } let(:custom_options) { { parent_barcode: parent.machine_barcode, parent: nil } } it { is_expected.not_to be_valid } @@ -56,20 +56,22 @@ context 'with valid data' do subject(:save) { phi_x_spiked_buffer.save } - let(:stock_study) { create :study } + let(:stock_study) { create(:study) } - let(:parent) { create :phi_x_stock_tube, study: stock_study } + let(:parent) { create(:phi_x_stock_tube, study: stock_study) } let(:study_id) { nil } let(:phi_x_spiked_buffer) do - build :phi_x_spiked_buffer, - name: 'Example', - parent_barcode: parent.human_barcode, - parent: nil, - concentration: '0.8', - volume: '10', - number: 2, - study_id: study_id + build( + :phi_x_spiked_buffer, + name: 'Example', + parent_barcode: parent.human_barcode, + parent: nil, + concentration: '0.8', + volume: '10', + number: 2, + study_id: study_id + ) end before { save } @@ -128,14 +130,14 @@ it 'sets study on the new aliquots' do phi_x_spiked_buffer.created_spiked_buffers.each do |tube| - expect(tube.aliquots).to all have_attributes(study_id: study_id) + expect(tube.aliquots).to all have_attributes(study_id:) end end end end context 'with invalid data' do - let(:phi_x_spiked_buffer) { build :phi_x_spiked_buffer, number: -2 } + let(:phi_x_spiked_buffer) { build(:phi_x_spiked_buffer, number: -2) } it 'returns false' do expect(phi_x_spiked_buffer.save).to be false @@ -145,17 +147,19 @@ describe '#tags' do let(:phi_x_spiked_buffer) do - build :phi_x_spiked_buffer, - name: 'Example', - parent_barcode: parent.human_barcode, - parent: nil, - concentration: '0.8', - volume: '10', - number: 2 + build( + :phi_x_spiked_buffer, + name: 'Example', + parent_barcode: parent.human_barcode, + parent: nil, + concentration: '0.8', + volume: '10', + number: 2 + ) end context 'when single' do - let(:parent) { create :phi_x_stock_tube, tag_option: 'Single' } + let(:parent) { create(:phi_x_stock_tube, tag_option: 'Single') } it 'returns Single' do expect(phi_x_spiked_buffer.tags).to eq('Single') @@ -163,7 +167,7 @@ end context 'when dual' do - let(:parent) { create :phi_x_stock_tube, tag_option: 'Dual' } + let(:parent) { create(:phi_x_stock_tube, tag_option: 'Dual') } it 'returns Dual' do expect(phi_x_spiked_buffer.tags).to eq('Dual') diff --git a/spec/models/phi_x/stock_spec.rb b/spec/models/phi_x/stock_spec.rb index 51a0a54097..6628947698 100644 --- a/spec/models/phi_x/stock_spec.rb +++ b/spec/models/phi_x/stock_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' RSpec.describe PhiX::Stock, :phi_x do - subject { build :phi_x_stock, custom_options } + subject { build(:phi_x_stock, custom_options) } context 'with suitable options' do let(:custom_options) { {} } # Fallback to factory defaults @@ -50,7 +50,7 @@ subject(:save) { phi_x_stock.save } let(:phi_x_stock) do - build :phi_x_stock, number: 2, name: 'Example', concentration: '0.8', tags: tags, study_id: study_id + build(:phi_x_stock, number: 2, name: 'Example', concentration: '0.8', tags: tags, study_id: study_id) end let(:tags) { 'Single' } @@ -82,7 +82,7 @@ end it 'sets study id the aliquot in each tube' do - phi_x_stock.created_stocks.each { |tube| expect(tube.aliquots).to all have_attributes(study_id: study_id) } + phi_x_stock.created_stocks.each { |tube| expect(tube.aliquots).to all have_attributes(study_id:) } end it 'generates an aliquot with PhiX sample' do @@ -118,7 +118,7 @@ end context 'with invalid data' do - let(:phi_x_stock) { build :phi_x_stock, number: -2 } + let(:phi_x_stock) { build(:phi_x_stock, number: -2) } it 'returns false' do expect(phi_x_stock.save).to be false diff --git a/spec/models/pick_list_spec.rb b/spec/models/pick_list_spec.rb index b2c6524d37..36672297f4 100644 --- a/spec/models/pick_list_spec.rb +++ b/spec/models/pick_list_spec.rb @@ -4,14 +4,14 @@ RSpec.describe PickList, :pick_list do subject(:pick_list) { described_class.new(pick_attributes: picks, asynchronous: asynchronous) } - let(:wells) { create_list :untagged_well, 2 } + let(:wells) { create_list(:untagged_well, 2) } let(:asynchronous) { false } let(:picks) { wells.map { |well| { source_receptacle: well } } } - let(:project) { create :project } + let(:project) { create(:project) } before do - rt = create :cherrypick_request_type, key: 'cherrypick' - create :cherrypick_pipeline, request_type: rt + rt = create(:cherrypick_request_type, key: 'cherrypick') + create(:cherrypick_pipeline, request_type: rt) end describe '#valid?' do @@ -22,13 +22,13 @@ end context 'when wells lack project information' do - let(:wells) { create_list :untagged_well, 2, project: nil } + let(:wells) { create_list(:untagged_well, 2, project: nil) } it { is_expected.not_to be_valid } end context 'when wells lack project information but the pick provides it' do - let(:wells) { create_list :untagged_well, 2, project: nil } + let(:wells) { create_list(:untagged_well, 2, project: nil) } let(:picks) { wells.map { |well| { source_receptacle: well, project: project } } } it { is_expected.to be_valid } diff --git a/spec/models/plate/quad_creator_spec.rb b/spec/models/plate/quad_creator_spec.rb index aae8a50e50..af9fd28052 100644 --- a/spec/models/plate/quad_creator_spec.rb +++ b/spec/models/plate/quad_creator_spec.rb @@ -7,8 +7,8 @@ RSpec.describe Plate::QuadCreator do subject(:quad_creator) { described_class.new(creation_options) } - let(:target_purpose) { create :plate_purpose, size: 384 } - let(:user) { create :user } + let(:target_purpose) { create(:plate_purpose, size: 384) } + let(:user) { create(:user) } let(:creation_options) { { parent_barcodes: parent_barcodes_hash, target_purpose: target_purpose, user: user } } before { allow(PlateBarcode).to receive(:create_barcode).and_return(build(:plate_barcode)) } @@ -45,7 +45,7 @@ end context 'when a parent is not a plate or rack' do - let(:tube) { create :tube } + let(:tube) { create(:tube) } # this should pass in the tube, not the barcode let(:parent_barcodes_hash) { { 'quad_1' => tube.machine_barcode } } @@ -61,7 +61,7 @@ end context 'when a parent is the wrong size' do - let(:plate) { create :plate, size: 384 } + let(:plate) { create(:plate, size: 384) } # this should pass in the plate, not the barcode let(:parent_barcodes_hash) { { 'quad_1' => plate.machine_barcode } } @@ -83,7 +83,7 @@ let(:number_of_parents) { 4 } # 2 wells in each, A1 & H12 - let(:parents) { create_list :plate_with_untagged_wells, number_of_parents, occupied_well_index: occupied_wells } + let(:parents) { create_list(:plate_with_untagged_wells, number_of_parents, occupied_well_index: occupied_wells) } let(:parent_barcodes_hash) do { 'quad_1' => parents[0].machine_barcode, @@ -144,7 +144,7 @@ end context 'with 1 parent' do - let(:parents) { create_list :plate_with_untagged_wells, 1, occupied_well_index: [0, 95] } # 2 wells, A1 & H12 + let(:parents) { create_list(:plate_with_untagged_wells, 1, occupied_well_index: [0, 95]) } # 2 wells, A1 & H12 let(:parent_barcodes_hash) { { 'quad_3' => parents[0].machine_barcode } } let(:quad_3_wells) { parents[0].wells.index_by(&:map_description) } @@ -171,7 +171,7 @@ context 'with parent tube racks' do context 'with 4 parents' do - let(:parents) { create_list :tube_rack_with_tubes, 4 } + let(:parents) { create_list(:tube_rack_with_tubes, 4) } let(:parent_barcodes_hash) do { 'quad_1' => parents[0].machine_barcode, @@ -213,8 +213,8 @@ context 'with a mixture of parent plates and racks' do # 2 wells in each, A1 & H12 - let(:parents_plates) { create_list :plate_with_untagged_wells, 2, occupied_well_index: [0, 95] } - let(:parents_racks) { create_list :tube_rack_with_tubes, 2 } + let(:parents_plates) { create_list(:plate_with_untagged_wells, 2, occupied_well_index: [0, 95]) } + let(:parents_racks) { create_list(:tube_rack_with_tubes, 2) } let(:parent_barcodes_hash) do { diff --git a/spec/models/plate/sample_tube_factory_spec.rb b/spec/models/plate/sample_tube_factory_spec.rb index f3a0be109e..03de26c907 100644 --- a/spec/models/plate/sample_tube_factory_spec.rb +++ b/spec/models/plate/sample_tube_factory_spec.rb @@ -4,8 +4,8 @@ RSpec.describe Plate::SampleTubeFactory do it 'sends print request' do - plate = create :plate, :with_wells, well_count: 2 - barcode_printer = create :barcode_printer + plate = create(:plate, :with_wells, well_count: 2) + barcode_printer = create(:barcode_printer) expect(RestClient).to receive(:post) diff --git a/spec/models/plate_purpose/additional_input_spec.rb b/spec/models/plate_purpose/additional_input_spec.rb index 5893196688..e5a25c6554 100644 --- a/spec/models/plate_purpose/additional_input_spec.rb +++ b/spec/models/plate_purpose/additional_input_spec.rb @@ -14,7 +14,7 @@ describe '#state_of' do subject(:state_of) { plate_purpose_input.state_of(plate) } - let(:plate) { create :plate, :with_wells, well_count: 2, purpose: plate_purpose_input } + let(:plate) { create(:plate, :with_wells, well_count: 2, purpose: plate_purpose_input) } context 'with no requests' do it 'is pending' do @@ -23,7 +23,7 @@ end context 'with ancestors' do - let(:parent_plate) { create :plate } + let(:parent_plate) { create(:plate) } let(:plate) { create(:target_plate, parent: parent_plate, purpose: plate_purpose_input) } context 'with no library requests' do @@ -45,7 +45,7 @@ end context 'with no ancestors' do - let(:plate) { create :plate_with_untagged_wells, well_count: 2, purpose: plate_purpose_input } + let(:plate) { create(:plate_with_untagged_wells, well_count: 2, purpose: plate_purpose_input) } context 'with no library requests' do it 'is pending' do diff --git a/spec/models/plate_purpose/input_spec.rb b/spec/models/plate_purpose/input_spec.rb index c595a9d709..d227d04f7a 100644 --- a/spec/models/plate_purpose/input_spec.rb +++ b/spec/models/plate_purpose/input_spec.rb @@ -5,8 +5,8 @@ # This behaviour is necessary because of limitations in generic lims # We can switch to the PlatePurpose::Input class once we're in limber describe PlatePurpose::Input do - let(:plate_purpose_input) { create :input_plate_purpose } - let(:plate) { create :plate, purpose: plate_purpose_input, well_count: 2, well_factory: :untagged_well } + let(:plate_purpose_input) { create(:input_plate_purpose) } + let(:plate) { create(:plate, purpose: plate_purpose_input, well_count: 2, well_factory: :untagged_well) } describe '#state_of' do subject(:state_of) { plate_purpose_input.state_of(plate) } @@ -18,7 +18,7 @@ end context 'with two pending requests' do - before { plate.wells.each { |well| create :request_library_creation, asset: well } } + before { plate.wells.each { |well| create(:request_library_creation, asset: well) } } it 'is passed' do expect(state_of).to eq('passed') @@ -26,7 +26,7 @@ end context 'with two failed requests' do - before { plate.wells.each { |well| create :request_library_creation, asset: well, state: 'failed' } } + before { plate.wells.each { |well| create(:request_library_creation, asset: well, state: 'failed') } } it 'is failed' do expect(state_of).to eq('failed') @@ -34,7 +34,7 @@ end context 'with two cancelled requests' do - before { plate.wells.each { |well| create :request_library_creation, asset: well, state: 'cancelled' } } + before { plate.wells.each { |well| create(:request_library_creation, asset: well, state: 'cancelled') } } it 'is cancelled' do expect(state_of).to eq('cancelled') @@ -43,8 +43,8 @@ context 'with a mix of cancelled and failed requests' do before do - create :request_library_creation, asset: plate.wells.first, state: 'cancelled' - create :request_library_creation, asset: plate.wells.last, state: 'failed' + create(:request_library_creation, asset: plate.wells.first, state: 'cancelled') + create(:request_library_creation, asset: plate.wells.last, state: 'failed') end it 'is failed' do @@ -53,7 +53,7 @@ end context 'with two active requests' do - before { plate.wells.each { |well| create_list :request_library_creation, 2, asset: well } } + before { plate.wells.each { |well| create_list(:request_library_creation, 2, asset: well) } } it 'is passed' do expect(state_of).to eq('passed') @@ -63,8 +63,8 @@ context 'with one active and one cancelled requests' do before do plate.wells.each do |well| - create :request_library_creation, asset: well - create :request_library_creation, asset: well, state: 'cancelled' + create(:request_library_creation, asset: well) + create(:request_library_creation, asset: well, state: 'cancelled') end end diff --git a/spec/models/plate_purpose_spec.rb b/spec/models/plate_purpose_spec.rb index f2a7fabf6e..67d8aa808e 100644 --- a/spec/models/plate_purpose_spec.rb +++ b/spec/models/plate_purpose_spec.rb @@ -4,7 +4,7 @@ require 'shared_contexts/limber_shared_context' describe PlatePurpose do - let(:plate_purpose) { create :plate_purpose, target_type: target_type, size: size } + let(:plate_purpose) { create(:plate_purpose, target_type:, size:) } shared_examples 'a plate factory' do before { expect(PlateBarcode).to receive(:create_barcode).and_return(build(:plate_barcode)) } diff --git a/spec/models/plate_spec.rb b/spec/models/plate_spec.rb index 47db2477ac..fa2c3e18e8 100644 --- a/spec/models/plate_spec.rb +++ b/spec/models/plate_spec.rb @@ -5,9 +5,9 @@ describe Plate do describe '#comments' do - let(:plate) { create :plate, well_count: 2 } + let(:plate) { create(:plate, well_count: 2) } - before { create :comment, commentable: plate, description: 'Comment on plate' } + before { create(:comment, commentable: plate, description: 'Comment on plate') } it 'allows comment addition' do plate.comments.create!(description: 'Works') @@ -24,9 +24,9 @@ context 'with requests out of the wells' do before do - submission = create :submission - request = create :well_request, asset: plate.wells.first, submission: submission - create :comment, commentable: request, description: 'Comment on request' + submission = create(:submission) + request = create(:well_request, asset: plate.wells.first, submission: submission) + create(:comment, commentable: request, description: 'Comment on request') plate.reload end @@ -45,11 +45,11 @@ context 'with requests in progress the wells' do before do - submission = create :submission - request = create :well_request, submission: submission - plate.wells.first.aliquots << create(:aliquot, request: request) - create :transfer_request, target_asset: plate.wells.first, submission: submission - create :comment, commentable: request, description: 'Comment on request' + submission = create(:submission) + request = create(:well_request, submission:) + plate.wells.first.aliquots << create(:aliquot, request:) + create(:transfer_request, target_asset: plate.wells.first, submission: submission) + create(:comment, commentable: request, description: 'Comment on request') plate.reload end @@ -62,12 +62,12 @@ context 'with multiple identical comments' do before do - submission = create :submission - request = create :well_request, asset: plate.wells.first, submission: submission - request2 = create :well_request, asset: plate.wells.last, submission: submission - create :comment, commentable: request, description: 'Duplicate comment' - create :comment, commentable: request2, description: 'Duplicate comment' - create :comment, commentable: plate, description: 'Duplicate comment' + submission = create(:submission) + request = create(:well_request, asset: plate.wells.first, submission: submission) + request2 = create(:well_request, asset: plate.wells.last, submission: submission) + create(:comment, commentable: request, description: 'Duplicate comment') + create(:comment, commentable: request2, description: 'Duplicate comment') + create(:comment, commentable: plate, description: 'Duplicate comment') plate.reload end @@ -82,7 +82,7 @@ context 'barcodes' do # Maintaining existing barcode behaviour context 'sanger barcodes' do - let(:plate) { create :plate } + let(:plate) { create(:plate) } describe '#human_barcode' do subject { plate.human_barcode } diff --git a/spec/models/plate_type_spec.rb b/spec/models/plate_type_spec.rb index 1b41ee4be3..e1c8079641 100644 --- a/spec/models/plate_type_spec.rb +++ b/spec/models/plate_type_spec.rb @@ -3,14 +3,14 @@ require 'rails_helper' describe PlateType do - let(:plate_type) { create :plate_type } + let(:plate_type) { create(:plate_type) } let(:invalid_plate_type) { described_class.new } before do - create :plate_type, name: 'ABgene_0765', maximum_volume: 800 - create :plate_type, name: 'ABgene_0800', maximum_volume: 180 - create :plate_type, name: 'FluidX075', maximum_volume: 500 - create :plate_type, name: 'FluidX03', maximum_volume: 280 + create(:plate_type, name: 'ABgene_0765', maximum_volume: 800) + create(:plate_type, name: 'ABgene_0800', maximum_volume: 180) + create(:plate_type, name: 'FluidX075', maximum_volume: 500) + create(:plate_type, name: 'FluidX03', maximum_volume: 280) end it 'has name and maximum volume' do diff --git a/spec/models/plate_volume_spec.rb b/spec/models/plate_volume_spec.rb index 13c5733808..5dc7a33e17 100644 --- a/spec/models/plate_volume_spec.rb +++ b/spec/models/plate_volume_spec.rb @@ -5,11 +5,11 @@ describe PlateVolume do let(:plate_with_barcodes_in_csv) do # This plate has a CSV file in which the barcode is listed in the column - create :plate, barcode: 'SQPD-1234567', well_count: 24, well_factory: :untagged_well, well_order: :row_order + create(:plate, barcode: 'SQPD-1234567', well_count: 24, well_factory: :untagged_well, well_order: :row_order) end let(:plate_without_barcodes_in_csv) do # This plate barcode is only used to name the volume check file - create :plate, barcode: 'SQPD-111', well_count: 24, well_factory: :untagged_well, well_order: :row_order + create(:plate, barcode: 'SQPD-111', well_count: 24, well_factory: :untagged_well, well_order: :row_order) end describe '::process_all_volume_check_files' do diff --git a/spec/models/pooling_spec.rb b/spec/models/pooling_spec.rb index 955bd4eb46..75a51d1903 100644 --- a/spec/models/pooling_spec.rb +++ b/spec/models/pooling_spec.rb @@ -3,12 +3,12 @@ require 'rails_helper' describe Pooling, :poolings do - let(:empty_lb_tube) { create :empty_library_tube, barcode: 1 } - let(:untagged_lb_tube1) { create :library_tube, barcode: 2 } - let(:untagged_lb_tube2) { create :library_tube, barcode: 3 } - let(:tagged_lb_tube1) { create :tagged_library_tube, barcode: 4 } - let(:tagged_lb_tube2) { create :tagged_library_tube, barcode: 5 } - let(:mx_tube) { create :multiplexed_library_tube, barcode: 6 } + let(:empty_lb_tube) { create(:empty_library_tube, barcode: 1) } + let(:untagged_lb_tube1) { create(:library_tube, barcode: 2) } + let(:untagged_lb_tube2) { create(:library_tube, barcode: 3) } + let(:tagged_lb_tube1) { create(:tagged_library_tube, barcode: 4) } + let(:tagged_lb_tube2) { create(:tagged_library_tube, barcode: 5) } + let(:mx_tube) { create(:multiplexed_library_tube, barcode: 6) } let(:stock_mx_tube_required) { false } let(:barcode_printer_option) { nil } let(:pooling) do @@ -109,7 +109,7 @@ # failing to disambiguate between them. context 'when the source tubes are from an mx library manifest' do before do - create :create_asset_request, asset: tagged_lb_tube1.receptacle + create(:create_asset_request, asset: tagged_lb_tube1.receptacle) create(:external_multiplexed_library_tube_creation_request, asset: tagged_lb_tube1.receptacle) end @@ -121,7 +121,7 @@ end context 'when a barcode printer is provided' do - let(:barcode_printer) { create :barcode_printer } + let(:barcode_printer) { create(:barcode_printer) } let(:barcode_printer_option) { barcode_printer.name } it 'executes print_job' do diff --git a/spec/models/primer_panel_spec.rb b/spec/models/primer_panel_spec.rb index 1caa304eb7..5423b23d0d 100644 --- a/spec/models/primer_panel_spec.rb +++ b/spec/models/primer_panel_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' RSpec.describe PrimerPanel do - let(:primer_panel) { create :primer_panel } + let(:primer_panel) { create(:primer_panel) } it 'validates a valid primer panel' do expect(primer_panel).to be_valid diff --git a/spec/models/pulldown/requests/isc_library_request_spec.rb b/spec/models/pulldown/requests/isc_library_request_spec.rb index 01f701da30..0472df90b9 100644 --- a/spec/models/pulldown/requests/isc_library_request_spec.rb +++ b/spec/models/pulldown/requests/isc_library_request_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' describe Pulldown::Requests::IscLibraryRequest do - subject { build :isc_request, bait_library: bait_library } + subject { build(:isc_request, bait_library:) } context 'with a active bait library' do let(:bait_library) { create(:bait_library) } diff --git a/spec/models/qc_report_spec.rb b/spec/models/qc_report_spec.rb index 8536b45de6..fdfd3e9803 100644 --- a/spec/models/qc_report_spec.rb +++ b/spec/models/qc_report_spec.rb @@ -15,26 +15,28 @@ attr_reader :study, :other_study, :stock_plate, :qc_report, :qc_metric_count before do - @study = create :study - @other_study = create :study - @stock_plate = create :plate, purpose: PlatePurpose.find_or_create_by(name: 'Stock plate') + @study = create(:study) + @other_study = create(:study) + @stock_plate = create(:plate, purpose: PlatePurpose.find_or_create_by(name: 'Stock plate')) [@study, @other_study].each do |study| 2.times do |i| - attribute = create :well_attribute, current_volume: 500, concentration: 200 - sample = create(:study_sample, study: study).sample + attribute = create(:well_attribute, current_volume: 500, concentration: 200) + sample = create(:study_sample, study:).sample sample.update!(sanger_sample_id: 'TEST1') well = - create :well, - samples: [sample], - plate: stock_plate, - map: create(:map, location_id: i), - well_attribute: attribute - well.aliquots.each { |a| a.update!(study: study) } + create( + :well, + samples: [sample], + plate: stock_plate, + map: create(:map, location_id: i), + well_attribute: attribute + ) + well.aliquots.each { |a| a.update!(study:) } end end - @qc_report = create :qc_report, study: @study + @qc_report = create(:qc_report, study: @study) @qc_metric_count = QcMetric.count Delayed::Worker.new.work_off end @@ -53,7 +55,7 @@ qc_report.qc_metrics.each do |metric| expect(metric.qc_decision).to eq('passed') expect(metric.proceed).to be_nil - expect(total_micrograms: 100, comment: '', sanger_sample_id: 'TEST1').to eq(metric.metrics) + expect(metric.metrics).to eq(total_micrograms: 100, comment: '', sanger_sample_id: 'TEST1') end end end @@ -73,65 +75,75 @@ :other_reported_sample before do - @study = create :study - @stock_plate = create :plate, purpose: PlatePurpose.find_or_create_by(name: 'Stock plate') + @study = create(:study) + @stock_plate = create(:plate, purpose: PlatePurpose.find_or_create_by(name: 'Stock plate')) - @current_criteria = create :product_criteria - @other_criteria = create :product_criteria + @current_criteria = create(:product_criteria) + @other_criteria = create(:product_criteria) @matching_report = - create :qc_report, - study: study, - exclude_existing: true, - product_criteria: current_criteria, - report_identifier: 'Override' - @other_report = create :qc_report, study: study, exclude_existing: true, product_criteria: other_criteria - - @attribute = create :well_attribute, current_volume: 500, concentration: 200 - - sample = create(:study_sample, study: study).sample + create( + :qc_report, + study: study, + exclude_existing: true, + product_criteria: current_criteria, + report_identifier: 'Override' + ) + @other_report = create(:qc_report, study: study, exclude_existing: true, product_criteria: other_criteria) + + @attribute = create(:well_attribute, current_volume: 500, concentration: 200) + + sample = create(:study_sample, study:).sample @unreported_sample = well = - create :well, - samples: [sample], - plate: stock_plate, - map: create(:map, location_id: 1), - well_attribute: attribute - well.aliquots.each { |a| a.update!(study: study) } - - sample = create(:study_sample, study: study).sample + create( + :well, + samples: [sample], + plate: stock_plate, + map: create(:map, location_id: 1), + well_attribute: attribute + ) + well.aliquots.each { |a| a.update!(study:) } + + sample = create(:study_sample, study:).sample well = - create :well, - samples: [sample], - plate: stock_plate, - map: create(:map, location_id: 2), - well_attribute: attribute - well.aliquots.each { |a| a.update!(study: study) } - create :qc_metric, asset: well, qc_report: matching_report - - sample = create(:study_sample, study: study).sample + create( + :well, + samples: [sample], + plate: stock_plate, + map: create(:map, location_id: 2), + well_attribute: attribute + ) + well.aliquots.each { |a| a.update!(study:) } + create(:qc_metric, asset: well, qc_report: matching_report) + + sample = create(:study_sample, study:).sample @other_reported_sample = well = - create :well, - samples: [sample], - plate: stock_plate, - map: create(:map, location_id: 3), - well_attribute: attribute - well.aliquots.each { |a| a.update!(study: study) } - create :qc_metric, asset: well, qc_report: other_report - - sample = create(:study_sample, study: study).sample + create( + :well, + samples: [sample], + plate: stock_plate, + map: create(:map, location_id: 3), + well_attribute: attribute + ) + well.aliquots.each { |a| a.update!(study:) } + create(:qc_metric, asset: well, qc_report: other_report) + + sample = create(:study_sample, study:).sample well = - create :well, - samples: [sample], - plate: stock_plate, - map: create(:map, location_id: 4), - well_attribute: attribute - well.aliquots.each { |a| a.update!(study: study) } - create :qc_metric, asset: well, qc_report: matching_report - create :qc_metric, asset: well, qc_report: other_report - - @qc_report = create :qc_report, study: study, exclude_existing: true, product_criteria: current_criteria + create( + :well, + samples: [sample], + plate: stock_plate, + map: create(:map, location_id: 4), + well_attribute: attribute + ) + well.aliquots.each { |a| a.update!(study:) } + create(:qc_metric, asset: well, qc_report: matching_report) + create(:qc_metric, asset: well, qc_report: other_report) + + @qc_report = create(:qc_report, study: study, exclude_existing: true, product_criteria: current_criteria) @qc_metric_count = QcMetric.count qc_report.generate! end @@ -164,7 +176,7 @@ attr_reader :qc_report let!(:study) { create(:study) } - let(:plate_purposes) { create_list :plate_purpose, 3 } + let(:plate_purposes) { create_list(:plate_purpose, 3) } let(:plate_purpose_names) { plate_purposes.map(&:name) } before do @@ -173,11 +185,13 @@ create(:well_for_qc_report, study: study, plate: create(:plate, plate_purpose: plate_purposes[2])) @qc_report = - create :qc_report, - study: study, - exclude_existing: false, - product_criteria: create(:product_criteria), - plate_purposes: plate_purpose_names + create( + :qc_report, + study: study, + exclude_existing: false, + product_criteria: create(:product_criteria), + plate_purposes: plate_purpose_names + ) qc_report.generate! end diff --git a/spec/models/qc_result/qc_result_spec.rb b/spec/models/qc_result/qc_result_spec.rb index 68143b16cd..eeed0789b5 100644 --- a/spec/models/qc_result/qc_result_spec.rb +++ b/spec/models/qc_result/qc_result_spec.rb @@ -51,11 +51,11 @@ end context 'with an asset' do - let(:asset) { build :receptacle } + let(:asset) { build(:receptacle) } it 'can update its asset' do expect(asset).to receive(:update_from_qc).with(an_instance_of(described_class)) - create :qc_result, asset: asset + create(:qc_result, asset:) end end end @@ -65,7 +65,7 @@ before { warren.clear_messages } - let(:resource) { build :qc_result } + let(:resource) { build(:qc_result) } let(:routing_key) { 'message.qc_result.' } it 'broadcasts the resource' do diff --git a/spec/models/qcable_creator_spec.rb b/spec/models/qcable_creator_spec.rb index 6d0fd85479..472ea1e315 100644 --- a/spec/models/qcable_creator_spec.rb +++ b/spec/models/qcable_creator_spec.rb @@ -13,7 +13,7 @@ it 'will create some qcables with a list of barcodes' do barcodes = 'CGAP-1,CGAP-2,CGAP-3,CGAP-4,CGAP-5' - qcable_creator = described_class.create(barcodes: barcodes, user: user, lot: lot) + qcable_creator = described_class.create(barcodes:, user:, lot:) expect(qcable_creator.qcables.count).to eq(5) expect(qcable_creator.qcables.first.barcodes.first.barcode).to eq('CGAP-1') expect(qcable_creator.qcables.last.barcodes.first.barcode).to eq('CGAP-5') diff --git a/spec/models/racked_tube_spec.rb b/spec/models/racked_tube_spec.rb index d6f583309a..f917dc18d7 100644 --- a/spec/models/racked_tube_spec.rb +++ b/spec/models/racked_tube_spec.rb @@ -3,8 +3,8 @@ require 'rails_helper' RSpec.describe RackedTube do describe '#create' do - let!(:tube_rack) { create :tube_rack } - let!(:tube) { create :tube } + let!(:tube_rack) { create(:tube_rack) } + let!(:tube) { create(:tube) } it 'allows a tube rack to be accessed from a tube' do racked_tube = described_class.create(tube_rack_id: tube_rack.id, tube_id: tube.id) @@ -24,8 +24,8 @@ end describe '#update' do - let!(:tube_rack) { create :tube_rack } - let!(:tube) { create :tube } + let!(:tube_rack) { create(:tube_rack) } + let!(:tube) { create(:tube) } let!(:racked_tube) { described_class.create(tube_rack_id: tube_rack.id, tube_id: tube.id) } it 'can be updated' do @@ -36,8 +36,8 @@ end describe '#destroy' do - let!(:tube_rack) { create :tube_rack } - let!(:tube) { create :tube } + let!(:tube_rack) { create(:tube_rack) } + let!(:tube) { create(:tube) } let!(:racked_tube) { described_class.create(tube_rack_id: tube_rack.id, tube_id: tube.id) } it 'can be destroyed without affecting the tube or tube rack' do @@ -49,10 +49,10 @@ end describe 'scope:: in_column_major_order' do - let(:tube_rack) { create :tube_rack } + let(:tube_rack) { create(:tube_rack) } let(:num_tubes) { locations.length } let(:locations) { %w[A01 H12 D04] } - let(:barcodes) { Array.new(num_tubes) { create :fluidx } } + let(:barcodes) { Array.new(num_tubes) { create(:fluidx) } } before do Array.new(num_tubes) do |i| diff --git a/spec/models/receptacle/downstream_aliquots_removal_spec.rb b/spec/models/receptacle/downstream_aliquots_removal_spec.rb index e660c6f25c..e140839344 100644 --- a/spec/models/receptacle/downstream_aliquots_removal_spec.rb +++ b/spec/models/receptacle/downstream_aliquots_removal_spec.rb @@ -32,7 +32,7 @@ context 'when any of the downstream assets have a batch' do let(:batch) { create(:sequencing_batch, request_count: 1) } - before { outer_requests_graph[2].update(batch: batch) } + before { outer_requests_graph[2].update(batch:) } it 'returns false' do expect(original_well).not_to be_allow_to_remove_downstream_aliquots diff --git a/spec/models/receptacle_spec.rb b/spec/models/receptacle_spec.rb index 31688d40d7..a4b733be15 100644 --- a/spec/models/receptacle_spec.rb +++ b/spec/models/receptacle_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' RSpec.describe Receptacle do - let(:receptacle) { create :receptacle } + let(:receptacle) { create(:receptacle) } # Uhh, looks like all our asset tests were labware tests! @@ -12,10 +12,10 @@ end describe '#most_recent_requests_as_target_group_by_same_source' do - let(:source) { create :receptacle } - let(:source2) { create :receptacle } - let(:requests_source1) { create_list :request, 3, { asset: source } } - let(:requests_source2) { create_list :request, 2, { asset: source2 } } + let(:source) { create(:receptacle) } + let(:source2) { create(:receptacle) } + let(:requests_source1) { create_list(:request, 3, { asset: source }) } + let(:requests_source2) { create_list(:request, 2, { asset: source2 }) } let(:requests) { [requests_source1, requests_source2].flatten } let(:expected) { [requests_source1.last, requests_source2.last].flatten } @@ -27,7 +27,7 @@ end describe '#update_from_qc' do - let(:qc_result) { build :qc_result, key: key, value: value, units: units, assay_type: 'assay', assay_version: 1 } + let(:qc_result) { build(:qc_result, key: key, value: value, units: units, assay_type: 'assay', assay_version: 1) } before { receptacle.update_from_qc(qc_result) } @@ -62,41 +62,41 @@ end describe '#pcr_cycles' do - let(:receptacle) { create :receptacle, pcr_cycles: 10 } + let(:receptacle) { create(:receptacle, pcr_cycles: 10) } it { expect(receptacle.pcr_cycles).to eq 10 } end describe '#submit_for_sequencing' do - let(:receptacle) { create :receptacle, submit_for_sequencing: true } + let(:receptacle) { create(:receptacle, submit_for_sequencing: true) } it { expect(receptacle.submit_for_sequencing).to be true } end describe '#sub_pool' do - let(:receptacle) { create :receptacle, sub_pool: 5 } + let(:receptacle) { create(:receptacle, sub_pool: 5) } it { expect(receptacle.sub_pool).to eq 5 } end describe '#coverage' do - let(:receptacle) { create :receptacle, coverage: 100 } + let(:receptacle) { create(:receptacle, coverage: 100) } it { expect(receptacle.coverage).to eq 100 } end describe '#diluent_volume' do - let(:receptacle) { create :receptacle, diluent_volume: 40 } + let(:receptacle) { create(:receptacle, diluent_volume: 40) } it { expect(receptacle.diluent_volume).to eq 40 } end describe '#attach_tag' do - let(:tag1) { create :tag } - let(:tag2) { create :tag } - let(:receptacle) { create :receptacle } + let(:tag1) { create(:tag) } + let(:tag2) { create(:tag) } + let(:receptacle) { create(:receptacle) } - before { receptacle.update(aliquots: aliquots) } + before { receptacle.update(aliquots:) } context 'when the receptacle has no aliquots' do let(:aliquots) { [] } @@ -108,7 +108,7 @@ context 'when the receptacle has one aliquot' do let(:aliquots) { [al1] } - let(:al1) { create :aliquot } + let(:al1) { create(:aliquot) } it 'can attach a tag to an aliquot' do receptacle.attach_tag(tag1, tag2) @@ -119,8 +119,8 @@ let(:aliquots) { [al1, al2] } context 'when every aliquot has a different tag_depth' do - let(:al1) { create :aliquot, tag_depth: 1 } - let(:al2) { create :aliquot, tag_depth: 2 } + let(:al1) { create(:aliquot, tag_depth: 1) } + let(:al2) { create(:aliquot, tag_depth: 2) } it 'can attach a tag to every aliquot' do receptacle.attach_tag(tag1, tag2) @@ -128,8 +128,8 @@ end context 'when there is duplication in tag_depths' do - let(:al1) { create :aliquot, tag_depth: 1 } - let(:al2) { create :aliquot, tag_depth: 1 } + let(:al1) { create(:aliquot, tag_depth: 1) } + let(:al2) { create(:aliquot, tag_depth: 1) } it 'raises an error' do expect { receptacle.attach_tag(tag1, tag2) }.to raise_error(StandardError) @@ -137,8 +137,8 @@ end context 'when there is no tag_depth' do - let(:al1) { create :aliquot } - let(:al2) { create :aliquot } + let(:al1) { create(:aliquot) } + let(:al2) { create(:aliquot) } it 'raises an error' do expect { receptacle.attach_tag(tag1, tag2) }.to raise_error(StandardError) diff --git a/spec/models/request/sample_compound_aliquot_transfer_spec.rb b/spec/models/request/sample_compound_aliquot_transfer_spec.rb index 0a7dfffa75..0b2a692020 100644 --- a/spec/models/request/sample_compound_aliquot_transfer_spec.rb +++ b/spec/models/request/sample_compound_aliquot_transfer_spec.rb @@ -5,23 +5,23 @@ # Test for module to provide support to create a compound sample during the # sequencing request start from all the samples at source of the request RSpec.describe 'Request::SampleCompoundAliquotTransfer' do - let(:samples) { create_list :sample, 3 } - let(:study1) { create :study } - let(:study2) { create :study } - let(:project1) { create :project } - let(:project2) { create :project } - let(:destination) { create :receptacle } - let(:source) { create :receptacle, aliquots: [aliquot1, aliquot2] } - let(:library_tube) { create :library_tube, receptacles: [source] } + let(:samples) { create_list(:sample, 3) } + let(:study1) { create(:study) } + let(:study2) { create(:study) } + let(:project1) { create(:project) } + let(:project2) { create(:project) } + let(:destination) { create(:receptacle) } + let(:source) { create(:receptacle, aliquots: [aliquot1, aliquot2]) } + let(:library_tube) { create(:library_tube, receptacles: [source]) } let(:sequencing_request) do create(:sequencing_request, asset: source, target_asset: destination, initial_study_id: study1.id) end - let(:tags) { create_list :tag, 3 } + let(:tags) { create_list(:tag, 3) } describe '#compound_samples_needed?' do context 'when number of aliquots is 1' do - let(:aliquot1) { create :aliquot, sample: samples[0], tag_id: 1, tag_depth: 1, project: project1 } - let(:source) { create :receptacle, aliquots: [aliquot1] } + let(:aliquot1) { create(:aliquot, sample: samples[0], tag_id: 1, tag_depth: 1, project: project1) } + let(:source) { create(:receptacle, aliquots: [aliquot1]) } it 'returns false' do expect(sequencing_request).not_to be_compound_samples_needed @@ -29,8 +29,12 @@ end context 'when there is no tag clash, using tags 1 and 2' do - let(:aliquot1) { create :aliquot, sample: samples[0], tag_id: tags[0].id, tag2_id: tags[1].id, project: project1 } - let(:aliquot2) { create :aliquot, sample: samples[1], tag_id: tags[0].id, tag2_id: tags[2].id, project: project1 } + let(:aliquot1) do + create(:aliquot, sample: samples[0], tag_id: tags[0].id, tag2_id: tags[1].id, project: project1) + end + let(:aliquot2) do + create(:aliquot, sample: samples[1], tag_id: tags[0].id, tag2_id: tags[2].id, project: project1) + end it 'returns false' do expect(sequencing_request).not_to be_compound_samples_needed @@ -39,10 +43,10 @@ context 'when there is a tag clash, using tags 1 and 2' do let(:aliquot1) do - create :aliquot, sample: samples[0], tag_id: tags[0].id, tag2_id: tags[1].id, tag_depth: 1, project: project1 + create(:aliquot, sample: samples[0], tag_id: tags[0].id, tag2_id: tags[1].id, tag_depth: 1, project: project1) end let(:aliquot2) do - create :aliquot, sample: samples[1], tag_id: tags[0].id, tag2_id: tags[1].id, tag_depth: 2, project: project1 + create(:aliquot, sample: samples[1], tag_id: tags[0].id, tag2_id: tags[1].id, tag_depth: 2, project: project1) end it 'returns true' do @@ -53,26 +57,30 @@ describe '#transfer_aliquots_into_compound_sample_aliquots' do let(:aliquot1) do - create :aliquot, - sample: samples[0], - tag_id: tags[0].id, - tag2_id: tags[1].id, - tag_depth: 1, - study: study1, - project: project1, - library_type: 'Standard', - library_id: 54 + create( + :aliquot, + sample: samples[0], + tag_id: tags[0].id, + tag2_id: tags[1].id, + tag_depth: 1, + study: study1, + project: project1, + library_type: 'Standard', + library_id: 54 + ) end let(:aliquot2) do - create :aliquot, - sample: samples[1], - tag_id: tags[0].id, - tag2_id: tags[1].id, - tag_depth: 2, - study: study1, - project: project1, - library_type: 'Standard', - library_id: 54 + create( + :aliquot, + sample: samples[1], + tag_id: tags[0].id, + tag2_id: tags[1].id, + tag_depth: 2, + study: study1, + project: project1, + library_type: 'Standard', + library_id: 54 + ) end context 'when no compound sample exists with the component samples' do @@ -219,31 +227,35 @@ end context 'when there are two compound samples' do - let(:samples_extra) { create_list :sample, 2 } + let(:samples_extra) { create_list(:sample, 2) } let(:aliquot3) do - create :aliquot, - sample: samples_extra[0], - tag_id: tags_extra[0].id, - tag2_id: tags_extra[1].id, - tag_depth: 1, - study: study2, - project: project2, - library_type: 'Standard', - library_id: 55 + create( + :aliquot, + sample: samples_extra[0], + tag_id: tags_extra[0].id, + tag2_id: tags_extra[1].id, + tag_depth: 1, + study: study2, + project: project2, + library_type: 'Standard', + library_id: 55 + ) end let(:aliquot4) do - create :aliquot, - sample: samples_extra[1], - tag_id: tags_extra[0].id, - tag2_id: tags_extra[1].id, - tag_depth: 2, - study: study2, - project: project2, - library_type: 'Standard', - library_id: 55 + create( + :aliquot, + sample: samples_extra[1], + tag_id: tags_extra[0].id, + tag2_id: tags_extra[1].id, + tag_depth: 2, + study: study2, + project: project2, + library_type: 'Standard', + library_id: 55 + ) end - let(:tags_extra) { create_list :tag, 2 } - let(:source) { create :receptacle, aliquots: [aliquot1, aliquot2, aliquot3, aliquot4] } + let(:tags_extra) { create_list(:tag, 2) } + let(:source) { create(:receptacle, aliquots: [aliquot1, aliquot2, aliquot3, aliquot4]) } before { sequencing_request.update!(initial_study_id: nil) } diff --git a/spec/models/request/traction/grid_ion_spec.rb b/spec/models/request/traction/grid_ion_spec.rb index ec57155c50..2dccbd3fb4 100644 --- a/spec/models/request/traction/grid_ion_spec.rb +++ b/spec/models/request/traction/grid_ion_spec.rb @@ -5,19 +5,21 @@ describe Request::Traction::GridIon do subject do - build :request_traction_grid_ion, - asset: well, - request_metadata_attributes: metadata, - order: order, - submission: submission, - request_type: request_type, - state: state + build( + :request_traction_grid_ion, + asset: well, + request_metadata_attributes: metadata, + order: order, + submission: submission, + request_type: request_type, + state: state + ) end let(:order) { build(:order, submission: submission, assets: [well], request_types: [request_type.id]) } - let(:request_type) { create :well_request_type } + let(:request_type) { create(:well_request_type) } let(:submission) { build(:submission) } - let(:well) { create :well } + let(:well) { create(:well) } let(:state) { 'pending' } context 'with valid metadata' do diff --git a/spec/models/request_event_spec.rb b/spec/models/request_event_spec.rb index 3f4428063f..48d2af1230 100644 --- a/spec/models/request_event_spec.rb +++ b/spec/models/request_event_spec.rb @@ -4,7 +4,7 @@ describe RequestEvent do context 'Customer Requests' do - let!(:request) { create :customer_request, asset: create(:well), target_asset: create(:well) } + let!(:request) { create(:customer_request, asset: create(:well), target_asset: create(:well)) } context 'creating requests' do it 'records a RequestEvent' do diff --git a/spec/models/request_information_type_spec.rb b/spec/models/request_information_type_spec.rb index b219efb829..985044ce06 100644 --- a/spec/models/request_information_type_spec.rb +++ b/spec/models/request_information_type_spec.rb @@ -1,21 +1,23 @@ # frozen_string_literal: true RSpec.describe RequestInformationType do - subject(:request_information_type) { described_class.new(name: name, key: key, label: label, data_type: data_type) } + subject(:request_information_type) { described_class.new(name:, key:, label:, data_type:) } let(:label) { 'example' } describe '#value_for' do subject { request_information_type.value_for(request, batch) } - let(:batch) { create :batch } + let(:batch) { create(:batch) } let(:request) do - create :sequencing_request, - request_metadata_attributes: { - read_length: 76, - created_at: Date.parse('2021-03-01') - }, - batch: batch + create( + :sequencing_request, + request_metadata_attributes: { + read_length: 76, + created_at: Date.parse('2021-03-01') + }, + batch: batch + ) end context 'when key is a request metadata' do @@ -36,8 +38,8 @@ context 'when key is an event' do before do - create :lab_event, descriptors: { 'My event' => 'old value' }, eventful: request, batch: batch - create :lab_event, descriptors: { 'My event' => 'new value' }, eventful: request, batch: batch + create(:lab_event, descriptors: { 'My event' => 'old value' }, eventful: request, batch: batch) + create(:lab_event, descriptors: { 'My event' => 'new value' }, eventful: request, batch: batch) end let(:name) { 'My event' } diff --git a/spec/models/request_spec.rb b/spec/models/request_spec.rb index 81886ed366..c97c7bafda 100644 --- a/spec/models/request_spec.rb +++ b/spec/models/request_spec.rb @@ -3,22 +3,22 @@ require 'rails_helper' RSpec.describe Request do - let(:study) { create :study } - let(:project) { create :project } - let(:submission) { create :submission } - let(:order1) { create :order, study: study, project: project, submission: submission } - let(:order2) { create :order, study: study, project: project, submission: submission } - let(:order3) { create :order, study: study, project: project, submission: submission } - let(:order4) { create :order_with_submission, study: study, project: project } + let(:study) { create(:study) } + let(:project) { create(:project) } + let(:submission) { create(:submission) } + let(:order1) { create(:order, study:, project:, submission:) } + let(:order2) { create(:order, study:, project:, submission:) } + let(:order3) { create(:order, study:, project:, submission:) } + let(:order4) { create(:order_with_submission, study:, project:) } describe '#for_order_including_submission_based_requests' do before do - @sequencing_request = create :request_with_sequencing_request_type, submission: submission - @request = create :request, order: order1, submission: submission, asset: @asset - @request2 = create :request, order: order2, submission: submission + @sequencing_request = create(:request_with_sequencing_request_type, submission:) + @request = create(:request, order: order1, submission: submission, asset: @asset) + @request2 = create(:request, order: order2, submission: submission) - @request3 = create :request, order: order4, submission: order4.submission - @sequencing_request2 = create :request_with_sequencing_request_type, submission: order4.submission + @request3 = create(:request, order: order4, submission: order4.submission) + @sequencing_request2 = create(:request_with_sequencing_request_type, submission: order4.submission) end it 'the sequencing requests are included' do @@ -59,16 +59,16 @@ describe '#next_request' do before do - @genotyping_request_type = create :request_type, name: 'genotyping' - @cherrypick_request_type = create :request_type, name: 'cherrypick', target_asset_type: nil + @genotyping_request_type = create(:request_type, name: 'genotyping') + @cherrypick_request_type = create(:request_type, name: 'cherrypick', target_asset_type: nil) @submission = FactoryHelp.submission( request_types: [@cherrypick_request_type, @genotyping_request_type].map(&:id), asset_group_name: 'to avoid asset errors' ) - @genotype_pipeline = create :pipeline, name: 'genotyping pipeline', request_types: [@genotyping_request_type] - @cherrypick_pipeline = create :pipeline, name: 'cherrypick pipeline', request_types: [@cherrypick_request_type] + @genotype_pipeline = create(:pipeline, name: 'genotyping pipeline', request_types: [@genotyping_request_type]) + @cherrypick_pipeline = create(:pipeline, name: 'cherrypick pipeline', request_types: [@cherrypick_request_type]) @request1 = create( @@ -83,7 +83,7 @@ end context 'with valid input' do - before { @request2 = create :request, submission: @submission, request_type: @genotyping_request_type } + before { @request2 = create(:request, submission: @submission, request_type: @genotyping_request_type) } it 'return the correct next request' do expect(@request1.next_requests).to eq([@request2]) @@ -92,7 +92,7 @@ context 'where asset hasnt been created for second request' do before do - @request2 = create :request, asset: nil, submission: @submission, request_type: @genotyping_request_type + @request2 = create(:request, asset: nil, submission: @submission, request_type: @genotyping_request_type) end it 'return the correct next request' do @@ -106,7 +106,7 @@ # so these tests use the submission builder. Please don't switch to building the requests # themselves via FactoryBot until the two behaviours are uncoupled describe '#next_requests' do - let(:submission) { create :submission, orders: [order1, order2], state: 'pending' } + let(:submission) { create(:submission, orders: [order1, order2], state: 'pending') } let(:order1) { create(:linear_submission, request_types: order1_request_types, request_options: request_options) } let(:order2) { create(:linear_submission, request_types: order2_request_types, request_options: request_options) } let(:order1_request1) do @@ -232,8 +232,8 @@ describe '#copy' do before do - @request_type = create :request_type - @request = create :request, request_type: @request_type, study: study, state: 'failed' + @request_type = create(:request_type) + @request = create(:request, request_type: @request_type, study: study, state: 'failed') @new_request = @request.copy end @@ -258,8 +258,8 @@ describe '#after_create' do context 'successful' do - let(:study) { create :study } - let(:request) { create :request, study: study } + let(:study) { create(:study) } + let(:request) { create(:request, study:) } it 'not have ActiveRecord errors' do expect(request.errors).to be_empty @@ -273,8 +273,8 @@ describe '#state' do before do - @request = create :request_suitable_for_starting, study: study - @user = create :admin + @request = create(:request_suitable_for_starting, study:) + @user = create(:admin) @user.grant_owner study end @@ -388,8 +388,8 @@ end describe '#eventful_studies' do - let(:asset) { create :untagged_well } - let(:request) { create :request, asset: asset, initial_study: study } + let(:asset) { create(:untagged_well) } + let(:request) { create(:request, asset: asset, initial_study: study) } context 'with no study itself' do let(:study) { nil } @@ -398,7 +398,7 @@ end context 'with a study itself' do - let(:study) { create :study } + let(:study) { create(:study) } it { expect(request.eventful_studies).to eq([study]) } end @@ -411,7 +411,7 @@ @all_states = @open_states + @closed_states - @all_states.each { |state| create :request, state: state } + @all_states.each { |state| create(:request, state:) } expect(described_class.count).to eq(@all_states.size) end @@ -439,7 +439,7 @@ describe '#customer_responsible' do before do - @request = create :library_creation_request + @request = create(:library_creation_request) @request.state = 'started' end @@ -459,18 +459,18 @@ describe '::progress_statistics' do subject { described_class.progress_statistics } - let(:request_type1) { create :request_type } - let(:request_type2) { create :request_type } + let(:request_type1) { create(:request_type) } + let(:request_type2) { create(:request_type) } before do - create_list :request, 2, state: 'pending', request_type: request_type1 - create_list :request, 1, state: 'started', request_type: request_type1 - create_list :request, 3, state: 'passed', request_type: request_type1 - create_list :request, 1, state: 'failed', request_type: request_type1 - create_list :request, 2, state: 'pending', request_type: request_type2 - create_list :request, 1, state: 'started', request_type: request_type2 - create_list :request, 3, state: 'cancelled', request_type: request_type2 - create_list :request, 1, state: 'failed', request_type: request_type2 + create_list(:request, 2, state: 'pending', request_type: request_type1) + create_list(:request, 1, state: 'started', request_type: request_type1) + create_list(:request, 3, state: 'passed', request_type: request_type1) + create_list(:request, 1, state: 'failed', request_type: request_type1) + create_list(:request, 2, state: 'pending', request_type: request_type2) + create_list(:request, 1, state: 'started', request_type: request_type2) + create_list(:request, 3, state: 'cancelled', request_type: request_type2) + create_list(:request, 1, state: 'failed', request_type: request_type2) end it 'returns a summary' do @@ -496,15 +496,15 @@ end describe '.get_all_comments' do - let(:labware) { create :labware } - let(:receptacle) { create :receptacle, labware: labware } - let(:request) { create :request, asset: receptacle } + let(:labware) { create(:labware) } + let(:receptacle) { create(:receptacle, labware:) } + let(:request) { create(:request, asset: receptacle) } before do - create :comment, commentable: labware, description: 'comment on labware' - create :comment, commentable: receptacle, description: 'comment on receptacle' - create :comment, commentable: request, description: 'first comment on request' - create :comment, commentable: request, description: 'second comment on request' + create(:comment, commentable: labware, description: 'comment on labware') + create(:comment, commentable: receptacle, description: 'comment on receptacle') + create(:comment, commentable: request, description: 'first comment on request') + create(:comment, commentable: request, description: 'second comment on request') end it 'returns all of the comments including associated labware, receptacle and request itself' do diff --git a/spec/models/request_type/validator/library_type_validator_spec.rb b/spec/models/request_type/validator/library_type_validator_spec.rb index 767ccd0b46..b4588e434e 100644 --- a/spec/models/request_type/validator/library_type_validator_spec.rb +++ b/spec/models/request_type/validator/library_type_validator_spec.rb @@ -3,8 +3,8 @@ require 'rails_helper' describe RequestType::Validator::LibraryTypeValidator do - let(:library_type) { create :library_type, name: 'MyLibraryType' } - let(:request_type) { create :library_creation_request_type, :with_library_types, library_type: library_type } + let(:library_type) { create(:library_type, name: 'MyLibraryType') } + let(:request_type) { create(:library_creation_request_type, :with_library_types, library_type:) } let(:validator) { described_class.new(request_type.id) } context 'when initialising' do @@ -34,8 +34,8 @@ end context 'when using default' do - let(:request_type) { create :request_type } - let(:library_type2) { create :library_type, name: 'MyDefaultLibraryType' } + let(:request_type) { create(:request_type) } + let(:library_type2) { create(:library_type, name: 'MyDefaultLibraryType') } context 'when a default library type is set' do before do diff --git a/spec/models/request_type_spec.rb b/spec/models/request_type_spec.rb index fa008faaee..0662c365be 100644 --- a/spec/models/request_type_spec.rb +++ b/spec/models/request_type_spec.rb @@ -6,7 +6,7 @@ context described_class do describe '#for_multiplexing?' do context 'when it is for multiplexing' do - let(:request_type) { create :multiplexed_library_creation_request_type } + let(:request_type) { create(:multiplexed_library_creation_request_type) } it 'return true' do expect(request_type).to be_for_multiplexing @@ -14,7 +14,7 @@ end context 'when it is not for multiplexing' do - let(:request_type) { create :library_creation_request_type } + let(:request_type) { create(:library_creation_request_type) } it 'return false' do expect(request_type).not_to be_for_multiplexing diff --git a/spec/models/robot/pick_data_spec.rb b/spec/models/robot/pick_data_spec.rb index b5518b3c2d..cc5d9785cb 100644 --- a/spec/models/robot/pick_data_spec.rb +++ b/spec/models/robot/pick_data_spec.rb @@ -10,11 +10,11 @@ describe '#picking_data_hash' do let(:time) { Time.zone.local(2010, 7, 12, 10, 25, 0) } - let(:source_plate_1) { create :plate, well_count: 2 } - let(:source_plate_2) { create :plate, well_count: 2 } - let(:source_plate_3) { create :plate, well_count: 2 } - let(:destination_plate) { create :plate, well_count: 9 } - let(:pipeline) { create :cherrypick_pipeline } + let(:source_plate_1) { create(:plate, well_count: 2) } + let(:source_plate_2) { create(:plate, well_count: 2) } + let(:source_plate_3) { create(:plate, well_count: 2) } + let(:destination_plate) { create(:plate, well_count: 9) } + let(:pipeline) { create(:cherrypick_pipeline) } let(:transfers) do # We generate the plates before the transfer map, as otherwise @@ -44,17 +44,19 @@ let(:requests) do transfers.map do |source, target| - create :cherrypick_request, - asset: source, - target_asset: target, - request_type: pipeline.request_types.first, - state: 'passed' + create( + :cherrypick_request, + asset: source, + target_asset: target, + request_type: pipeline.request_types.first, + state: 'passed' + ) end end - let(:user) { create :user } + let(:user) { create(:user) } - let(:batch) { create :batch, requests: requests, pipeline: pipeline, user: user } + let(:batch) { create(:batch, requests:, pipeline:, user:) } shared_examples_for 'a picking process' do # This is how the output of the process should be displayed: @@ -145,8 +147,8 @@ end context 'when we have several plates and needs to use several picks' do - let(:destination_plate) { create :plate, well_count: 10 } - let(:plates) { create_list :plate, 5, well_count: 2 } + let(:destination_plate) { create(:plate, well_count: 10) } + let(:plates) { create_list(:plate, 5, well_count: 2) } let(:picks) do { 'A1' => [plates[0], 'A1'], @@ -168,18 +170,20 @@ context 'when we create the requests in different order' do let(:requests) do transfers.to_a.reverse.map do |source, target| - create :cherrypick_request, - asset: source, - target_asset: target, - request_type: pipeline.request_types.first, - state: 'passed' + create( + :cherrypick_request, + asset: source, + target_asset: target, + request_type: pipeline.request_types.first, + state: 'passed' + ) end end it_behaves_like 'a picking process' context 'when we have a control' do - let(:control_plate) { create :control_plate, sample_count: 2 } + let(:control_plate) { create(:control_plate, sample_count: 2) } let(:expected_pick) { { 1 => %w[A2 B2 A1 B1], 2 => %w[C1 D1 E1 F1], 3 => %w[G1 H1] } } before { plates[4] = control_plate } diff --git a/spec/models/robot/verification/source_dest_beds_spec.rb b/spec/models/robot/verification/source_dest_beds_spec.rb index 03b030c91b..136b2caebb 100644 --- a/spec/models/robot/verification/source_dest_beds_spec.rb +++ b/spec/models/robot/verification/source_dest_beds_spec.rb @@ -34,10 +34,10 @@ end end - let(:source_plate_1) { create :plate, well_count: 2 } - let(:source_plate_3) { create :plate, well_count: 2 } - let(:destination_plate) { create :plate, well_count: 9 } - let(:pipeline) { create :cherrypick_pipeline } + let(:source_plate_1) { create(:plate, well_count: 2) } + let(:source_plate_3) { create(:plate, well_count: 2) } + let(:destination_plate) { create(:plate, well_count: 9) } + let(:pipeline) { create(:cherrypick_pipeline) } let(:max_beds) { 17 } let(:transfers) do @@ -62,18 +62,20 @@ let(:requests) do transfers.map do |source, target| - create :cherrypick_request, - asset: source, - target_asset: target, - request_type: pipeline.request_types.first, - state: 'passed' + create( + :cherrypick_request, + asset: source, + target_asset: target, + request_type: pipeline.request_types.first, + state: 'passed' + ) end end - let(:batch) { create :batch, requests: requests, pipeline: pipeline } + let(:batch) { create(:batch, requests:, pipeline:) } context 'without control plates' do - let(:source_plate_2) { create :plate, well_count: 2 } + let(:source_plate_2) { create(:plate, well_count: 2) } let(:expected_layout) do { 1 => [ @@ -93,7 +95,7 @@ end context 'with control plates' do - let(:source_plate_2) { create :control_plate, well_count: 2 } + let(:source_plate_2) { create(:control_plate, well_count: 2) } let(:expected_layout) do { 1 => [ diff --git a/spec/models/robot/verification/source_dest_control_beds_spec.rb b/spec/models/robot/verification/source_dest_control_beds_spec.rb index 8785f6f502..f4969abdeb 100644 --- a/spec/models/robot/verification/source_dest_control_beds_spec.rb +++ b/spec/models/robot/verification/source_dest_control_beds_spec.rb @@ -29,10 +29,10 @@ end end - let(:source_plate_1) { create :plate, well_count: 2 } - let(:source_plate_3) { create :plate, well_count: 2 } - let(:destination_plate) { create :plate, well_count: 9 } - let(:pipeline) { create :cherrypick_pipeline } + let(:source_plate_1) { create(:plate, well_count: 2) } + let(:source_plate_3) { create(:plate, well_count: 2) } + let(:destination_plate) { create(:plate, well_count: 9) } + let(:pipeline) { create(:cherrypick_pipeline) } let(:max_beds) { 17 } let(:transfers) do @@ -57,20 +57,22 @@ let(:requests) do transfers.map do |source, target| - create :cherrypick_request, - asset: source, - target_asset: target, - request_type: pipeline.request_types.first, - state: 'passed' + create( + :cherrypick_request, + asset: source, + target_asset: target, + request_type: pipeline.request_types.first, + state: 'passed' + ) end end - let(:batch) { create :batch, requests: requests, pipeline: pipeline } - let(:user) { create :user } - let(:robot) { create :hamilton, barcode: '444' } + let(:batch) { create(:batch, requests:, pipeline:) } + let(:user) { create(:user) } + let(:robot) { create(:hamilton, barcode: '444') } context 'without control plates' do - let(:source_plate_2) { create :plate, well_count: 2 } + let(:source_plate_2) { create(:plate, well_count: 2) } let(:expected_layout) do { 1 => [ @@ -131,7 +133,7 @@ context 'without control plates and multiple picks' do let(:max_beds) { 2 } - let(:source_plate_2) { create :plate, well_count: 2 } + let(:source_plate_2) { create(:plate, well_count: 2) } let(:expected_layout) do { 1 => [ @@ -153,7 +155,7 @@ end context 'with control plates' do - let(:source_plate_2) { create :control_plate, well_count: 2 } + let(:source_plate_2) { create(:control_plate, well_count: 2) } let(:expected_layout) do { 1 => [ @@ -215,7 +217,7 @@ context 'with control plates and multiple picks' do let(:max_beds) { 1 } - let(:source_plate_2) { create :control_plate, well_count: 2 } + let(:source_plate_2) { create(:control_plate, well_count: 2) } let(:expected_layout) do # NOTE: This generates three picks. # In theory this should be possible to do in two, as the control bed diff --git a/spec/models/sample/metadata_spec.rb b/spec/models/sample/metadata_spec.rb index 8fcc27164b..8803116f0f 100644 --- a/spec/models/sample/metadata_spec.rb +++ b/spec/models/sample/metadata_spec.rb @@ -4,10 +4,10 @@ RSpec.describe Sample::Metadata do describe '#user_of_consent_withdrawn' do - let(:user) { create :user } - let(:sample) { create :sample } - let(:sample_metadata) { create :sample_metadata_for_api } - let(:sample_with_metadata) { create :sample, sample_metadata: sample_metadata } + let(:user) { create(:user) } + let(:sample) { create(:sample) } + let(:sample_metadata) { create(:sample_metadata_for_api) } + let(:sample_with_metadata) { create(:sample, sample_metadata:) } before { sample.sample_metadata.update(user_id_of_consent_withdrawn: user.id) } diff --git a/spec/models/sample_manifest/uploader_spec.rb b/spec/models/sample_manifest/uploader_spec.rb index 83a30e20c5..2faa736466 100644 --- a/spec/models/sample_manifest/uploader_spec.rb +++ b/spec/models/sample_manifest/uploader_spec.rb @@ -14,7 +14,7 @@ let(:test_file_name) { 'test_file.xlsx' } let(:test_file) { Rack::Test::UploadedFile.new(Rails.root.join(test_file_name), '') } - let(:user) { create :user } + let(:user) { create(:user) } after(:all) { SampleManifestExcel.reset! } diff --git a/spec/models/sample_manifest_spec.rb b/spec/models/sample_manifest_spec.rb index 9b5b09e9db..866ee304d4 100644 --- a/spec/models/sample_manifest_spec.rb +++ b/spec/models/sample_manifest_spec.rb @@ -6,12 +6,12 @@ # result in repeatedly indenting them to the level of the last call in the previous chain RSpec.describe SampleManifest, :sample_manifest do - let(:user) { create :user } - let(:study) { create :study } + let(:user) { create(:user) } + let(:study) { create(:study) } describe '#default_filename' do let(:date) { Date.parse('25/10/2018') } - let(:manifest) { create :sample_manifest, study: study, created_at: date } + let(:manifest) { create(:sample_manifest, study: study, created_at: date) } it 'includes the information requested' do expect(manifest.default_filename).to eq("#{study.id}stdy_manifest_#{manifest.id}_251018") @@ -19,7 +19,7 @@ end describe '#generate' do - let(:manifest) { create :sample_manifest, study: study, count: count, asset_type: asset_type, purpose: purpose } + let(:manifest) { create(:sample_manifest, study:, count:, asset_type:, purpose:) } let(:purpose) { nil } let(:first_plate_barcode) { build(:plate_barcode) } let(:second_plate_barcode) { build(:plate_barcode) } @@ -81,7 +81,7 @@ end context 'with a custom purpose' do - let(:purpose) { create :plate_purpose, size: 2 } + let(:purpose) { create(:plate_purpose, size: 2) } let(:count) { 1 } before { manifest.generate } @@ -140,7 +140,7 @@ end context 'with a custom purpose' do - let(:purpose) { create :plate_purpose, size: 2 } + let(:purpose) { create(:plate_purpose, size: 2) } let(:count) { 1 } before { manifest.generate } @@ -152,7 +152,7 @@ end context 'with no rapid generation' do - let(:manifest) { create :sample_manifest, study: study } + let(:manifest) { create(:sample_manifest, study:) } it 'adds created broadcast event when sample manifest is created' do expect { manifest.generate }.to change(BroadcastEvent::SampleManifestCreated, :count).by(1) @@ -329,7 +329,7 @@ describe '#updated_by!' do let(:plate_behaviour_core) { SampleManifest::PlateBehaviour::Core.new(described_class.new) } - let(:well_with_plate) { create :well_with_sample_and_plate } + let(:well_with_plate) { create(:well_with_sample_and_plate) } it 'adds an event to the plate' do plate_behaviour_core.updated_by!(user, [well_with_plate.samples.first]) @@ -358,10 +358,12 @@ describe '#pools' do let(:manifest) do - create :plate_sample_manifest_with_manifest_assets, - study: study, - asset_type: 'plate', - num_samples_per_well: num_samples_per_well + create( + :plate_sample_manifest_with_manifest_assets, + study: study, + asset_type: 'plate', + num_samples_per_well: num_samples_per_well + ) end context 'when there is only one sample per well' do diff --git a/spec/models/sample_spec.rb b/spec/models/sample_spec.rb index 08042600fa..daa588a53d 100644 --- a/spec/models/sample_spec.rb +++ b/spec/models/sample_spec.rb @@ -51,15 +51,15 @@ context 'can be included in submission' do it 'knows if it was registered through manifest' do - stand_alone_sample = create :sample + stand_alone_sample = create(:sample) expect(stand_alone_sample).not_to be_registered_through_manifest - sample_manifest = create :tube_sample_manifest_with_samples + sample_manifest = create(:tube_sample_manifest_with_samples) sample_manifest.samples.each { |sample| expect(sample).to be_registered_through_manifest } end it 'knows when it can be included in submission if it was registered through manifest' do - sample_manifest = create :tube_sample_manifest_with_samples + sample_manifest = create(:tube_sample_manifest_with_samples) sample_manifest.samples.each { |sample| expect(sample).not_to be_can_be_included_in_submission } sample = sample_manifest.samples.first sample.sample_metadata.supplier_name = 'new sample' @@ -67,15 +67,15 @@ end it 'knows when it can be included in submission if it was not registered through manifest' do - sample = create :sample + sample = create(:sample) expect(sample).to be_can_be_included_in_submission end end context 'consent withdraw' do - let(:user) { create :user } + let(:user) { create(:user) } let(:time) { DateTime.now } - let(:sample) { create :sample } + let(:sample) { create(:sample) } before do sample.update(consent_withdrawn: true, date_of_consent_withdrawn: time, user_id_of_consent_withdrawn: user.id) @@ -136,14 +136,12 @@ end it 'can have a priority' do - %w[backlog surveillance priority].each do |priority| - expect(build(:sample, priority: priority).priority).to eq(priority) - end + %w[backlog surveillance priority].each { |priority| expect(build(:sample, priority:).priority).to eq(priority) } end end context 'updating supplier name' do - let(:sample) { create :sample } + let(:sample) { create(:sample) } it 'validates that supplier name allows only ASCII characters' do expect(sample.sample_metadata.supplier_name).to be_nil @@ -262,7 +260,7 @@ end context '(DPL-148) on updating sample metadata' do - let(:sample) { create :sample } + let(:sample) { create(:sample) } it 'triggers warehouse update', :warren do expect do diff --git a/spec/models/sequencing_request_spec.rb b/spec/models/sequencing_request_spec.rb index 846df5c234..ef9906818c 100644 --- a/spec/models/sequencing_request_spec.rb +++ b/spec/models/sequencing_request_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' RSpec.describe SequencingRequest do - let(:library_tube) { create :library_tube } + let(:library_tube) { create(:library_tube) } let(:sequencing_request) { create(:sequencing_request, asset: library_tube) } describe '#ready?' do @@ -17,7 +17,7 @@ end context 'with empty assets' do - let(:library_tube) { create :empty_library_tube } + let(:library_tube) { create(:empty_library_tube) } it { is_expected.to be false } end @@ -38,12 +38,16 @@ context 'with upstream requests' do before do library_tube.create_scanned_into_lab_event!(content: '2018-01-01') - create :library_creation_request_for_testing_sequencing_requests, - target_asset: library_tube, - state: library_request_1_state - create :library_creation_request_for_testing_sequencing_requests, - target_asset: library_tube, - state: library_request_2_state + create( + :library_creation_request_for_testing_sequencing_requests, + target_asset: library_tube, + state: library_request_1_state + ) + create( + :library_creation_request_for_testing_sequencing_requests, + target_asset: library_tube, + state: library_request_2_state + ) end # Nothing has happened yet! @@ -94,7 +98,7 @@ subject { request.loading_concentration } let(:request) do - create :complete_sequencing_request, event_descriptors: { 'Lane loading concentration (pM)' => user_input } + create(:complete_sequencing_request, event_descriptors: { 'Lane loading concentration (pM)' => user_input }) end context 'with the expected input' do @@ -136,13 +140,13 @@ end context 'on start' do - let(:samples) { create_list :sample, 2 } - let(:study) { create :study, samples: samples } - let(:project) { create :project } - let(:destination) { create :receptacle } + let(:samples) { create_list(:sample, 2) } + let(:study) { create(:study, samples:) } + let(:project) { create(:project) } + let(:destination) { create(:receptacle) } let(:aliquots) { [aliquot1, aliquot2] } - let(:source) { create :receptacle, aliquots: aliquots } - let(:library_tube) { create :library_tube, receptacles: [source] } + let(:source) { create(:receptacle, aliquots:) } + let(:library_tube) { create(:library_tube, receptacles: [source]) } let(:sequencing_request) do create( :sequencing_request, @@ -152,11 +156,11 @@ initial_project: project ) end - let(:tags) { create_list :tag, 4 } + let(:tags) { create_list(:tag, 4) } context 'when compound samples are not necessary because each aliquot has a unique tag combination' do - let(:aliquot1) { create :aliquot, sample: samples[0], tag_id: tags[0].id, tag2_id: tags[1].id, study: study } - let(:aliquot2) { create :aliquot, sample: samples[1], tag_id: tags[0].id, tag2_id: tags[2].id, study: study } + let(:aliquot1) { create(:aliquot, sample: samples[0], tag_id: tags[0].id, tag2_id: tags[1].id, study: study) } + let(:aliquot2) { create(:aliquot, sample: samples[1], tag_id: tags[0].id, tag2_id: tags[2].id, study: study) } it 'performs a normal transfer of aliquots' do expect(sequencing_request.target_asset.aliquots.count).to eq(0) @@ -169,22 +173,26 @@ context 'when compound samples are necessary because each aliquot does not have a unique tag combination' do context 'when there is one tag combination' do let(:aliquot1) do - create :aliquot, - sample: samples[0], - tag_id: tags[0].id, - tag2_id: tags[1].id, - tag_depth: 1, - study: study, - project: project + create( + :aliquot, + sample: samples[0], + tag_id: tags[0].id, + tag2_id: tags[1].id, + tag_depth: 1, + study: study, + project: project + ) end let(:aliquot2) do - create :aliquot, - sample: samples[1], - tag_id: tags[0].id, - tag2_id: tags[1].id, - tag_depth: 2, - study: study, - project: project + create( + :aliquot, + sample: samples[1], + tag_id: tags[0].id, + tag2_id: tags[1].id, + tag_depth: 2, + study: study, + project: project + ) end it 'creates a compound sample and transfers an aliquot of it' do @@ -196,18 +204,18 @@ end context 'when there are two tag combinations' do - let(:samples) { create_list :sample, 4 } + let(:samples) { create_list(:sample, 4) } let(:aliquot1) do - create :aliquot, sample: samples[0], tag_id: tags[0].id, tag2_id: tags[1].id, tag_depth: 1, study: study + create(:aliquot, sample: samples[0], tag_id: tags[0].id, tag2_id: tags[1].id, tag_depth: 1, study: study) end let(:aliquot2) do - create :aliquot, sample: samples[1], tag_id: tags[0].id, tag2_id: tags[1].id, tag_depth: 2, study: study + create(:aliquot, sample: samples[1], tag_id: tags[0].id, tag2_id: tags[1].id, tag_depth: 2, study: study) end let(:aliquot3) do - create :aliquot, sample: samples[2], tag_id: tags[2].id, tag2_id: tags[3].id, tag_depth: 1, study: study + create(:aliquot, sample: samples[2], tag_id: tags[2].id, tag2_id: tags[3].id, tag_depth: 1, study: study) end let(:aliquot4) do - create :aliquot, sample: samples[3], tag_id: tags[2].id, tag2_id: tags[3].id, tag_depth: 2, study: study + create(:aliquot, sample: samples[3], tag_id: tags[2].id, tag2_id: tags[3].id, tag_depth: 2, study: study) end let(:aliquots) { [aliquot1, aliquot2, aliquot3, aliquot4] } diff --git a/spec/models/specific_tube_creations_spec.rb b/spec/models/specific_tube_creations_spec.rb index ec731b1235..3bc2b5c45b 100644 --- a/spec/models/specific_tube_creations_spec.rb +++ b/spec/models/specific_tube_creations_spec.rb @@ -7,8 +7,8 @@ subject(:specific_tube_creation) { described_class.new(creation_parameters) } let(:child_purpose) { create(:tube_purpose) } - let(:user) { create :user } - let(:parent) { create :plate } + let(:user) { create(:user) } + let(:parent) { create(:plate) } end shared_context 'with common test setup' do @@ -71,7 +71,7 @@ context 'with custom names' do let(:names) { %w[example_1 example_2] } let(:purpose_count) { 2 } - let(:tube_attributes) { names.map { |name| { name: name } } } + let(:tube_attributes) { names.map { |name| { name: } } } let(:creation_parameters) do { user: user, child_purposes: [child_purpose] * purpose_count, parent: parent, tube_attributes: tube_attributes } end diff --git a/spec/models/state_changer/initial_stock_tube_spec.rb b/spec/models/state_changer/initial_stock_tube_spec.rb index 4fb18fc1fc..7a853061e6 100644 --- a/spec/models/state_changer/initial_stock_tube_spec.rb +++ b/spec/models/state_changer/initial_stock_tube_spec.rb @@ -4,28 +4,23 @@ require 'spec_helper' RSpec.describe StateChanger::InitialStockTube do - let(:state_changer) do - described_class.new( - labware: labware, - target_state: target_state, - user: user, - customer_accepts_responsibility: customer_accepts_responsibility - ) - end + let(:state_changer) { described_class.new(labware:, target_state:, user:, customer_accepts_responsibility:) } - let(:user) { build_stubbed :user } + let(:user) { build_stubbed(:user) } let(:customer_accepts_responsibility) { false } - let(:labware) { create :tube } - let(:submission) { build_stubbed :submission } - let(:well) { create :well } + let(:labware) { create(:tube) } + let(:submission) { build_stubbed(:submission) } + let(:well) { create(:well) } let!(:transfer_request) do - create :transfer_request, - asset: well, - target_asset: labware.receptacle, - state: transfer_request_state, - outer_request: request + create( + :transfer_request, + asset: well, + target_asset: labware.receptacle, + state: transfer_request_state, + outer_request: request + ) end - let!(:request) { create :customer_request, asset: well, state: request_state, submission: submission } + let!(:request) { create(:customer_request, asset: well, state: request_state, submission: submission) } before do well.stock_wells << well diff --git a/spec/models/state_changer/input_plate_spec.rb b/spec/models/state_changer/input_plate_spec.rb index 4ef4d3361a..6973a9a682 100644 --- a/spec/models/state_changer/input_plate_spec.rb +++ b/spec/models/state_changer/input_plate_spec.rb @@ -14,7 +14,7 @@ customer_accepts_responsibility: customer_accepts_responsibility ) end - let(:user) { build_stubbed :user } + let(:user) { build_stubbed(:user) } let(:contents) { [] } let(:customer_accepts_responsibility) { false } diff --git a/spec/models/state_changer/mx_tube_spec.rb b/spec/models/state_changer/mx_tube_spec.rb index 791f1945de..5f4d07d3a4 100644 --- a/spec/models/state_changer/mx_tube_spec.rb +++ b/spec/models/state_changer/mx_tube_spec.rb @@ -4,22 +4,15 @@ require 'spec_helper' RSpec.describe StateChanger::MxTube do - let(:state_changer) do - described_class.new( - labware: labware, - target_state: target_state, - user: user, - customer_accepts_responsibility: customer_accepts_responsibility - ) - end + let(:state_changer) { described_class.new(labware:, target_state:, user:, customer_accepts_responsibility:) } - let(:user) { build_stubbed :user } + let(:user) { build_stubbed(:user) } let(:customer_accepts_responsibility) { false } - let(:labware) { create :multiplexed_library_tube } - let(:transfer_request) { create :transfer_request, target_asset: labware.receptacle, state: transfer_request_state } - let(:request) { create :request, target_asset: labware.receptacle, state: request_state, order: order } + let(:labware) { create(:multiplexed_library_tube) } + let(:transfer_request) { create(:transfer_request, target_asset: labware.receptacle, state: transfer_request_state) } + let(:request) { create(:request, target_asset: labware.receptacle, state: request_state, order: order) } let(:requests) { [request] } - let(:order) { create :order } + let(:order) { create(:order) } def create_requests_and_transfers transfer_request @@ -398,9 +391,9 @@ def create_requests_and_transfers end context 'when there are multiple orders' do - let(:request2) { create :request, target_asset: labware.receptacle, state: request_state, order: order2 } + let(:request2) { create(:request, target_asset: labware.receptacle, state: request_state, order: order2) } let(:requests) { [request, request2] } - let(:order2) { create :order } + let(:order2) { create(:order) } it 'fires an event per order' do expect(BroadcastEvent::PoolReleased.count).to eq(2) diff --git a/spec/models/state_changer/qcable_labware_spec.rb b/spec/models/state_changer/qcable_labware_spec.rb index b8a57f5fa7..cbd7ff1acc 100644 --- a/spec/models/state_changer/qcable_labware_spec.rb +++ b/spec/models/state_changer/qcable_labware_spec.rb @@ -5,9 +5,9 @@ RSpec.describe StateChanger::QcableLabware do let(:state_changer) { described_class.new(labware: labware, target_state: 'exhausted', user: user) } - let!(:qcable) { create :qcable, asset: labware, state: 'available' } - let(:labware) { create :plate } - let(:user) { build_stubbed :user } + let!(:qcable) { create(:qcable, asset: labware, state: 'available') } + let(:labware) { create(:plate) } + let(:user) { build_stubbed(:user) } it 'sets library type on aliquots' do state_changer.update_labware_state diff --git a/spec/models/state_changer/qcable_library_plate_spec.rb b/spec/models/state_changer/qcable_library_plate_spec.rb index 1fd755cd82..0cc3bb6777 100644 --- a/spec/models/state_changer/qcable_library_plate_spec.rb +++ b/spec/models/state_changer/qcable_library_plate_spec.rb @@ -15,7 +15,7 @@ end let(:labware) { instance_double('Plate', wells: [well]) } # rubocop:todo RSpec/VerifiedDoubleReference let(:well) { instance_double('Well', aliquots: [aliquot]) } # rubocop:todo RSpec/VerifiedDoubleReference - let(:user) { build_stubbed :user } + let(:user) { build_stubbed(:user) } let(:contents) { [] } let(:customer_accepts_responsibility) { false } let(:aliquot) do diff --git a/spec/models/state_changer/standard_plate_spec.rb b/spec/models/state_changer/standard_plate_spec.rb index b12f2b10ca..59e44f42fc 100644 --- a/spec/models/state_changer/standard_plate_spec.rb +++ b/spec/models/state_changer/standard_plate_spec.rb @@ -13,7 +13,7 @@ customer_accepts_responsibility: customer_accepts_responsibility ) end - let(:user) { build_stubbed :user } + let(:user) { build_stubbed(:user) } let(:contents) { [] } let(:customer_accepts_responsibility) { false } @@ -41,7 +41,7 @@ end context 'when the plate is cancelled at the end of the pipeline' do - let(:target_plate) { create :final_plate } + let(:target_plate) { create(:final_plate) } let(:library_requests) { target_plate.wells.flat_map(&:requests_as_target) } let(:target_state) { 'cancelled' } @@ -52,7 +52,7 @@ end context 'when the plate is failed at the end of the pipeline' do - let(:target_plate) { create :final_plate } + let(:target_plate) { create(:final_plate) } let(:library_requests) { target_plate.wells.flat_map(&:requests_as_target) } let(:target_state) { 'failed' } @@ -109,7 +109,7 @@ let(:target_state) { 'failed' } # override default target plate creation - let(:target_plate) { create :plate, well_count: 4 } + let(:target_plate) { create(:plate, well_count: 4) } let(:target_wells) { target_plate.wells.index_by(&:map_description) } before do @@ -125,30 +125,36 @@ target_well: target_wells['A1'], source_well: parent_wells['A1'] ) - create :transfer_request, - asset: parent_wells['A1'], - target_asset: target_wells['A1'], - outer_request: source_well_a1_request + create( + :transfer_request, + asset: parent_wells['A1'], + target_asset: target_wells['A1'], + outer_request: source_well_a1_request + ) target_wells['B1'].stock_well_links << build( :stock_well_link, target_well: target_wells['B1'], source_well: parent_wells['A1'] ) - create :transfer_request, - asset: parent_wells['A1'], - target_asset: target_wells['B1'], - outer_request: source_well_a1_request + create( + :transfer_request, + asset: parent_wells['A1'], + target_asset: target_wells['B1'], + outer_request: source_well_a1_request + ) target_wells['C1'].stock_well_links << build( :stock_well_link, target_well: target_wells['C1'], source_well: parent_wells['A1'] ) - create :transfer_request, - asset: parent_wells['A1'], - target_asset: target_wells['C1'], - outer_request: source_well_a1_request + create( + :transfer_request, + asset: parent_wells['A1'], + target_asset: target_wells['C1'], + outer_request: source_well_a1_request + ) # D1 created by transferring from parent B1 (2nd library request) target_wells['D1'].stock_well_links << build( @@ -156,10 +162,12 @@ target_well: target_wells['D1'], source_well: parent_wells['B1'] ) - create :transfer_request, - asset: parent_wells['B1'], - target_asset: target_wells['D1'], - outer_request: source_well_b1_request + create( + :transfer_request, + asset: parent_wells['B1'], + target_asset: target_wells['D1'], + outer_request: source_well_b1_request + ) end context 'when the other wells are not failed' do diff --git a/spec/models/state_changer/stock_tube_spec.rb b/spec/models/state_changer/stock_tube_spec.rb index 30708aecb7..55803cc4e9 100644 --- a/spec/models/state_changer/stock_tube_spec.rb +++ b/spec/models/state_changer/stock_tube_spec.rb @@ -4,23 +4,16 @@ require 'spec_helper' RSpec.describe StateChanger::StockTube do - let(:state_changer) do - described_class.new( - labware: labware, - target_state: target_state, - user: user, - customer_accepts_responsibility: customer_accepts_responsibility - ) - end + let(:state_changer) { described_class.new(labware:, target_state:, user:, customer_accepts_responsibility:) } - let(:user) { build_stubbed :user } + let(:user) { build_stubbed(:user) } let(:customer_accepts_responsibility) { false } - let(:labware) { create :tube } - let!(:transfer_request) { create :transfer_request, target_asset: labware.receptacle, state: transfer_request_state } - let!(:request) { create :request, target_asset: labware.receptacle, state: request_state } + let(:labware) { create(:tube) } + let!(:transfer_request) { create(:transfer_request, target_asset: labware.receptacle, state: transfer_request_state) } + let!(:request) { create(:request, target_asset: labware.receptacle, state: request_state) } before do - labware.receptacle.aliquots << build(:aliquot, request: request) + labware.receptacle.aliquots << build(:aliquot, request:) state_changer.update_labware_state end diff --git a/spec/models/std_library_request_spec.rb b/spec/models/std_library_request_spec.rb index 67f94842ad..cdf547dbd3 100644 --- a/spec/models/std_library_request_spec.rb +++ b/spec/models/std_library_request_spec.rb @@ -3,10 +3,10 @@ require 'rails_helper' RSpec.describe IlluminaHtp::Requests::StdLibraryRequest do - let(:tagged_well) { create :tagged_well } + let(:tagged_well) { create(:tagged_well) } describe '#pass' do - subject { create :library_request, target_asset: tagged_well, state: state } + subject { create(:library_request, target_asset: tagged_well, state: state) } let(:state) { 'started' } @@ -17,9 +17,7 @@ end describe '#request_metadata' do - subject do - build :library_request, request_metadata_attributes: request_metadata_attributes, request_type: request_type - end + subject { build(:library_request, request_metadata_attributes:, request_type:) } let(:fragment_size_required_from) { 1 } let(:fragment_size_required_to) { 20 } @@ -27,15 +25,10 @@ let(:pcr_cycles) { 8 } let(:request_metadata_attributes) do - { - fragment_size_required_from: fragment_size_required_from, - fragment_size_required_to: fragment_size_required_to, - library_type: library_type, - pcr_cycles: pcr_cycles - } + { fragment_size_required_from:, fragment_size_required_to:, library_type:, pcr_cycles: } end - let(:request_type) { create :library_creation_request_type } + let(:request_type) { create(:library_creation_request_type) } let(:expected_pool_info) do { diff --git a/spec/models/stock_stamper_spec.rb b/spec/models/stock_stamper_spec.rb index 13d3b72159..cf68a232f3 100644 --- a/spec/models/stock_stamper_spec.rb +++ b/spec/models/stock_stamper_spec.rb @@ -5,16 +5,16 @@ require 'timecop' describe StockStamper do - let(:plate) { create :plate_with_3_wells } - let!(:user) { create :user, login: 'abc', barcode: 'ID41440E' } + let(:plate) { create(:plate_with_3_wells) } + let!(:user) { create(:user, login: 'abc', barcode: 'ID41440E') } before do # Set the plate barcode to be a DN barcode plate.barcodes = [Barcode.build_sanger_code39({ prefix: 'DN', number: '1' })] - create :plate_type, name: 'ABgene_0765', maximum_volume: 800 - create :plate_type, name: 'ABgene_0800', maximum_volume: 180 - create :plate_type, name: 'FluidX075', maximum_volume: 500 - create :plate_type, name: 'FluidX03', maximum_volume: 280 + create(:plate_type, name: 'ABgene_0765', maximum_volume: 800) + create(:plate_type, name: 'ABgene_0800', maximum_volume: 180) + create(:plate_type, name: 'FluidX075', maximum_volume: 500) + create(:plate_type, name: 'FluidX03', maximum_volume: 280) @attributes = { user_barcode: '2470041440697', diff --git a/spec/models/study_spec.rb b/spec/models/study_spec.rb index 410a566681..d2e512b929 100644 --- a/spec/models/study_spec.rb +++ b/spec/models/study_spec.rb @@ -12,25 +12,25 @@ requests = [].tap do |r| # Cancelled - 3.times { r << (create :cancelled_request, study: study, request_type: request_type) } + 3.times { r << (create(:cancelled_request, study:, request_type:)) } # Failed - r << (create :failed_request, study: study, request_type: request_type) + r << (create(:failed_request, study:, request_type:)) # Passed - 3.times { r << (create :passed_request, study: study, request_type: request_type) } + 3.times { r << (create(:passed_request, study:, request_type:)) } - r << (create :passed_request, study: study, request_type: request_type_2) - r << (create :passed_request, study: study, request_type: request_type_3) - r << (create :passed_request, study: study, request_type: request_type_3) + r << (create(:passed_request, study: study, request_type: request_type_2)) + r << (create(:passed_request, study: study, request_type: request_type_3)) + r << (create(:passed_request, study: study, request_type: request_type_3)) # Pending - r << (create :pending_request, study: study, request_type: request_type) - r << (create :pending_request, study: study, request_type: request_type_3) + r << (create(:pending_request, study:, request_type:)) + r << (create(:pending_request, study: study, request_type: request_type_3)) end # we have to hack t - requests.each { |request| request.asset.aliquots.each { |a| a.update(study: study) } } + requests.each { |request| request.asset.aliquots.each { |a| a.update(study:) } } study.save! expect(study).to be_valid @@ -38,9 +38,9 @@ end it 'validates uniqueness of name (case sensitive)' do - study_1 = create :study, name: 'Study_name' - study_2 = build :study, name: 'Study_name' - study_3 = build :study, name: 'Study_NAME' + study_1 = create(:study, name: 'Study_name') + study_2 = build(:study, name: 'Study_name') + study_3 = build(:study, name: 'Study_NAME') expect(study_2.valid?).to be false expect(study_2.errors.messages.length).to eq 1 expect(study_2.errors.full_messages).to include 'Name has already been taken' @@ -249,7 +249,7 @@ end end - create_list(:order, 2, study: study) + create_list(:order, 2, study:) study.projects.each { |project| project.enforce_quotas = true } study.save! @@ -377,9 +377,9 @@ describe '#each_well_for_qc_report_in_batches' do let!(:study) { create(:study) } let(:purpose_1) { PlatePurpose.stock_plate_purpose } - let(:purpose_2) { create :plate_purpose } - let(:purpose_3) { create :plate_purpose } - let(:purpose_4) { create :plate_purpose } + let(:purpose_2) { create(:plate_purpose) } + let(:purpose_3) { create(:plate_purpose) } + let(:purpose_4) { create(:plate_purpose) } let!(:well_1) { create(:well_for_qc_report, study: study, plate: create(:plate, plate_purpose: purpose_1)) } let!(:well_2) { create(:well_for_qc_report, study: study, plate: create(:plate, plate_purpose: purpose_2)) } let!(:well_3) { create(:well_for_qc_report, study: study, plate: create(:plate, plate_purpose: purpose_3)) } @@ -412,16 +412,16 @@ describe '#mailing_list_of_managers' do subject { study.mailing_list_of_managers } - let(:study) { create :study } + let(:study) { create(:study) } context 'with a manger' do - before { create :manager, authorizable: study, email: 'manager@example.com' } + before { create(:manager, authorizable: study, email: 'manager@example.com') } it { is_expected.to eq ['manager@example.com'] } end context 'without a manger' do - before { create :admin } + before { create(:admin) } it { is_expected.to eq ['ssr@example.com'] } end @@ -858,8 +858,8 @@ end context '(DPL-148) on updating user roles' do - let(:study) { create :study } - let(:user) { create :user } + let(:study) { create(:study) } + let(:user) { create(:user) } it 'triggers warehouse update', :warren do expect { user.grant_follower(study) }.to change(Warren.handler.messages, :count).from(0) diff --git a/spec/models/submission/submission_creator_spec.rb b/spec/models/submission/submission_creator_spec.rb index 52145bbcda..e6c1581a83 100644 --- a/spec/models/submission/submission_creator_spec.rb +++ b/spec/models/submission/submission_creator_spec.rb @@ -4,16 +4,14 @@ describe Submission::SubmissionCreator do describe '#order_fields' do - let(:user) { create :user } + let(:user) { create(:user) } let(:creator) { described_class.new(user, template_id: template.id) } context 'a full template' do - let(:library_type) { create :library_type } - let(:library_creation_request_type) do - create(:library_request_type, :with_library_types, library_type: library_type) - end + let(:library_type) { create(:library_type) } + let(:library_creation_request_type) { create(:library_request_type, :with_library_types, library_type:) } let(:template) do - create :submission_template, request_types: [library_creation_request_type, create(:sequencing_request_type)] + create(:submission_template, request_types: [library_creation_request_type, create(:sequencing_request_type)]) end it 'finds the appropriate order fields' do diff --git a/spec/models/submission_spec.rb b/spec/models/submission_spec.rb index f06ab635cd..844f660113 100644 --- a/spec/models/submission_spec.rb +++ b/spec/models/submission_spec.rb @@ -94,13 +94,13 @@ end it 'knows all samples that can not be included in submission' do - sample_manifest = create :tube_sample_manifest_with_samples + sample_manifest = create(:tube_sample_manifest_with_samples) sample_manifest.samples.first.sample_metadata.update(supplier_name: 'new_name') samples = sample_manifest.samples[1..] - order1 = create :order, assets: sample_manifest.labware + order1 = create(:order, assets: sample_manifest.labware) - asset = create :sample_tube - order2 = create :order, assets: [asset.receptacle] + asset = create(:sample_tube) + order2 = create(:order, assets: [asset.receptacle]) submission = described_class.new(user: create(:user), orders: [order1, order2]) @@ -108,24 +108,24 @@ end describe '#used_tags' do - let(:submission) { create :submission } - let(:request_1) { create :request, submission: submission } - let(:request_2) { create :request, submission: submission } - let(:tag_a) { create :tag } - let(:tag2_a) { create :tag } - let(:tag_b) { create :tag } - let(:tag2_b) { create :tag } + let(:submission) { create(:submission) } + let(:request_1) { create(:request, submission:) } + let(:request_2) { create(:request, submission:) } + let(:tag_a) { create(:tag) } + let(:tag2_a) { create(:tag) } + let(:tag_b) { create(:tag) } + let(:tag2_b) { create(:tag) } before do # Some untagged aliquots upstream of tagging - create :untagged_aliquot, request: request_1 - create :untagged_aliquot, request: request_2 + create(:untagged_aliquot, request: request_1) + create(:untagged_aliquot, request: request_2) # Once tagged, we may have multiple tagged aliquots - create :aliquot, request: request_1, tag: tag_a, tag2: tag2_a - create :aliquot, request: request_2, tag: tag_b, tag2: tag2_b - create :aliquot, request: request_1, tag: tag_a, tag2: tag2_a - create :aliquot, request: request_2, tag: tag_b, tag2: tag2_b + create(:aliquot, request: request_1, tag: tag_a, tag2: tag2_a) + create(:aliquot, request: request_2, tag: tag_b, tag2: tag2_b) + create(:aliquot, request: request_1, tag: tag_a, tag2: tag2_a) + create(:aliquot, request: request_2, tag: tag_b, tag2: tag2_b) end it 'returns an array of used tag pairs' do diff --git a/spec/models/tag2_layout_spec.rb b/spec/models/tag2_layout_spec.rb index d51b417d47..52d01fdc00 100644 --- a/spec/models/tag2_layout_spec.rb +++ b/spec/models/tag2_layout_spec.rb @@ -3,11 +3,11 @@ require 'rails_helper' RSpec.describe Tag2Layout do - subject { create :tag2_layout, plate: plate, tag: tag } + subject { create(:tag2_layout, plate:, tag:) } - let(:plate) { create :plate_with_untagged_wells, :with_submissions, sample_count: 2 } - let(:tag) { create :tag } - let!(:tag2_layout_template) { create :tag2_layout_template, tag: tag } + let(:plate) { create(:plate_with_untagged_wells, :with_submissions, sample_count: 2) } + let(:tag) { create(:tag) } + let!(:tag2_layout_template) { create(:tag2_layout_template, tag:) } it 'applies its tag to every well of the plate' do expect(subject.plate.wells).to be_present diff --git a/spec/models/tag2_layout_template_spec.rb b/spec/models/tag2_layout_template_spec.rb index 618d69597a..c9cf955545 100644 --- a/spec/models/tag2_layout_template_spec.rb +++ b/spec/models/tag2_layout_template_spec.rb @@ -3,12 +3,12 @@ require 'rails_helper' RSpec.describe Tag2LayoutTemplate do - subject { tag2_layout_template.create! plate: plate, tag: tag, user: user } + subject { tag2_layout_template.create! plate:, tag:, user: } - let(:plate) { create :plate_with_untagged_wells, :with_submissions, sample_count: 2 } - let(:tag) { create :tag } - let(:user) { create :user } - let(:tag2_layout_template) { create :tag2_layout_template, tag: tag } + let(:plate) { create(:plate_with_untagged_wells, :with_submissions, sample_count: 2) } + let(:tag) { create(:tag) } + let(:user) { create(:user) } + let(:tag2_layout_template) { create(:tag2_layout_template, tag:) } it 'applies its tag to every well of the plate' do expect(subject.plate.wells).to be_present diff --git a/spec/models/tag_group/adapter_type_spec.rb b/spec/models/tag_group/adapter_type_spec.rb index 762f371bb8..bbe1d0bbdb 100644 --- a/spec/models/tag_group/adapter_type_spec.rb +++ b/spec/models/tag_group/adapter_type_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' describe TagGroup::AdapterType do - subject(:adapter_type) { build :adapter_type, name: name } + subject(:adapter_type) { build(:adapter_type, name:) } context 'when it has a unique name' do let(:name) { 'name' } @@ -18,7 +18,7 @@ end context 'when it is in use' do - before { create :tag_group, adapter_type: adapter_type } + before { create(:tag_group, adapter_type:) } it { is_expected.to be false } end @@ -45,7 +45,7 @@ end context 'when its name is already in use' do - before { create :adapter_type, name: 'name' } + before { create(:adapter_type, name: 'name') } let(:name) { 'name' } diff --git a/spec/models/tag_group_spec.rb b/spec/models/tag_group_spec.rb index 3d32ddc190..e983d0dcf4 100644 --- a/spec/models/tag_group_spec.rb +++ b/spec/models/tag_group_spec.rb @@ -52,10 +52,10 @@ describe '#adapter_type_name' do subject { tag_group.adapter_type_name } - let(:tag_group) { build_stubbed :tag_group, adapter_type: adapter_type } + let(:tag_group) { build_stubbed(:tag_group, adapter_type:) } context 'when an adapter type is specified' do - let(:adapter_type) { build_stubbed :adapter_type, name: 'name' } + let(:adapter_type) { build_stubbed(:adapter_type, name: 'name') } it { is_expected.to eq 'name' } end @@ -69,7 +69,7 @@ describe '#by_adaptor_type' do let!(:adapter_type) { create(:adapter_type, name: 'test_adapter') } - let!(:tag_group) { create(:tag_group, adapter_type: adapter_type) } + let!(:tag_group) { create(:tag_group, adapter_type:) } context 'a tag group' do it 'is selected when the scope adapter name matches' do diff --git a/spec/models/tag_layout_spec.rb b/spec/models/tag_layout_spec.rb index cb1f537a81..795ae63d2b 100644 --- a/spec/models/tag_layout_spec.rb +++ b/spec/models/tag_layout_spec.rb @@ -10,11 +10,11 @@ def generate_tag_layout(plate, tag_type = :tag) plate.wells.with_aliquots.each_with_object({}) { |w, h| h[w.map_description] = w.aliquots.map(&tag_type) } end - let(:plate) { create :plate_with_untagged_wells, well_count: 8 } - let(:tag_group) { create :tag_group, tag_count: tag_count } + let(:plate) { create(:plate_with_untagged_wells, well_count: 8) } + let(:tag_group) { create(:tag_group, tag_count:) } let(:tag2_group) { nil } let(:tag_count) { 16 } - let(:user) { create :user } + let(:user) { create(:user) } let(:initial_tag) { 0 } shared_examples 'a tag layout' do @@ -33,7 +33,7 @@ def generate_tag_layout(plate, tag_type = :tag) end context 'substitutions' do - let(:tag_layout) { build_stubbed :tag_layout } + let(:tag_layout) { build_stubbed(:tag_layout) } it 'defaults to an empty hash' do expect(tag_layout.substitutions).to eq({}) @@ -41,18 +41,7 @@ def generate_tag_layout(plate, tag_type = :tag) end context 'layouts' do - before do - create( - :tag_layout, - plate: plate, - user: user, - tag_group: tag_group, - tag2_group: tag2_group, - walking_by: walking_by, - direction: direction, - initial_tag: initial_tag - ) - end + before { create(:tag_layout, plate:, user:, tag_group:, tag2_group:, walking_by:, direction:, initial_tag:) } context 'by_column' do let(:direction) { 'column' } @@ -108,9 +97,9 @@ def generate_tag_layout(plate, tag_type = :tag) let(:direction) { 'combinatorial by row' } context 'with a 384 well plate' do - let(:plate) { create :plate_with_untagged_wells, sample_count: 4 * 16, size: 384 } + let(:plate) { create(:plate_with_untagged_wells, sample_count: 4 * 16, size: 384) } let(:tag_count) { 384 } - let(:tag2_group) { create :tag_group, tag_count: tag_count } + let(:tag2_group) { create(:tag_group, tag_count:) } let(:expected_tag_layout) do { 'A1' => [1], @@ -269,9 +258,9 @@ def generate_tag_layout(plate, tag_type = :tag) let(:direction) { 'column then row' } context 'with a 384 well plate' do - let(:plate) { create :plate_with_untagged_wells, sample_count: 4 * 16, size: 384 } + let(:plate) { create(:plate_with_untagged_wells, sample_count: 4 * 16, size: 384) } let(:tag_count) { 384 } - let(:tag2_group) { create :tag_group, tag_count: tag_count } + let(:tag2_group) { create(:tag_group, tag_count:) } let(:expected_tag_layout) do { 'A1' => [1], @@ -426,9 +415,9 @@ def generate_tag_layout(plate, tag_type = :tag) let(:direction) { 'column' } context 'with a 384 well plate' do - let(:plate) { create :plate_with_untagged_wells, sample_count: 4 * 16, size: 384 } + let(:plate) { create(:plate_with_untagged_wells, sample_count: 4 * 16, size: 384) } let(:tag_count) { 384 } - let(:tag2_group) { create :tag_group, tag_count: tag_count } + let(:tag2_group) { create(:tag_group, tag_count:) } let(:expected_tag_layout) do { 'A1' => [1], @@ -583,9 +572,9 @@ def generate_tag_layout(plate, tag_type = :tag) let(:direction) { 'inverse column' } context 'with a 384 well plate' do - let(:plate) { create :plate_with_untagged_wells, sample_count: 4 * 16, size: 384 } + let(:plate) { create(:plate_with_untagged_wells, sample_count: 4 * 16, size: 384) } let(:tag_count) { 384 } - let(:tag2_group) { create :tag_group, tag_count: tag_count } + let(:tag2_group) { create(:tag_group, tag_count:) } let(:expected_tag_layout) do { 'A1' => [96], @@ -740,9 +729,9 @@ def generate_tag_layout(plate, tag_type = :tag) let(:direction) { 'row' } context 'with a 384 well plate' do - let(:plate) { create :plate_with_untagged_wells, sample_count: 4 * 16, size: 384 } + let(:plate) { create(:plate_with_untagged_wells, sample_count: 4 * 16, size: 384) } let(:tag_count) { 384 } - let(:tag2_group) { create :tag_group, tag_count: tag_count } + let(:tag2_group) { create(:tag_group, tag_count:) } let(:expected_tag_layout) do { 'A1' => [1], @@ -1025,7 +1014,7 @@ def generate_tag_layout(plate, tag_type = :tag) end context 'with a tag2 group' do - let(:tag2_group) { create :tag_group, tag_count: tag_count } + let(:tag2_group) { create(:tag_group, tag_count:) } let(:walking_by) { 'wells of plate' } let(:direction) { 'column' } let(:expected_tag_layout) do diff --git a/spec/models/tag_layout_template_spec.rb b/spec/models/tag_layout_template_spec.rb index 65473dc58c..609301233f 100644 --- a/spec/models/tag_layout_template_spec.rb +++ b/spec/models/tag_layout_template_spec.rb @@ -8,26 +8,28 @@ # and is tested there. describe TagLayoutTemplate do let(:template) do - build :tag_layout_template, - direction_algorithm: direction_algorithm, - walking_algorithm: walking_algorithm, - tag2_group: tag2_group, - tags: ['AAA'] + build( + :tag_layout_template, + direction_algorithm: direction_algorithm, + walking_algorithm: walking_algorithm, + tag2_group: tag2_group, + tags: ['AAA'] + ) end describe '#create!' do - subject { template.create!(plate: plate, user: user) } + subject { template.create!(plate:, user:) } - let(:user) { build :user } + let(:user) { build(:user) } - let(:plate) { create :plate } + let(:plate) { create(:plate) } let(:tag2_group) { nil } let(:enforce_uniqueness) { nil } context 'by plate in columns' do let(:direction_algorithm) { 'TagLayout::InColumns' } let(:walking_algorithm) { 'TagLayout::WalkWellsOfPlate' } - let(:plate) { create :plate, :with_submissions, well_count: 1 } + let(:plate) { create(:plate, :with_submissions, well_count: 1) } it { is_expected.to be_a TagLayout } @@ -54,7 +56,7 @@ context 'with a tag2 group' do let(:enforce_uniqueness) { true } - let(:tag2_group) { create :tag_group_with_tags } + let(:tag2_group) { create(:tag_group_with_tags) } it { is_expected.to be_a TagLayout } @@ -79,10 +81,10 @@ end context 'with a tag2 group with uniqueness unenforced' do - subject { template.create!(plate: plate, user: user, enforce_uniqueness: enforce_uniqueness) } + subject { template.create!(plate:, user:, enforce_uniqueness:) } let(:enforce_uniqueness) { nil } - let(:tag2_group) { create :tag_group_with_tags } + let(:tag2_group) { create(:tag_group_with_tags) } it { is_expected.to be_a TagLayout } diff --git a/spec/models/tag_set_spec.rb b/spec/models/tag_set_spec.rb index 243f9917a7..336c169d16 100644 --- a/spec/models/tag_set_spec.rb +++ b/spec/models/tag_set_spec.rb @@ -16,8 +16,8 @@ it 'is valid when the tag groups have the same adapter type' do adapter_type = build(:adapter_type) - tag_group = create(:tag_group, adapter_type: adapter_type) - tag_group2 = create(:tag_group, adapter_type: adapter_type) + tag_group = create(:tag_group, adapter_type:) + tag_group2 = create(:tag_group, adapter_type:) tag_set = build(:tag_set, tag_group: tag_group, tag2_group: tag_group2) expect(tag_set).to be_valid end diff --git a/spec/models/tag_substitutions_spec.rb b/spec/models/tag_substitutions_spec.rb index af24e4729f..c5dd4d1ae2 100644 --- a/spec/models/tag_substitutions_spec.rb +++ b/spec/models/tag_substitutions_spec.rb @@ -15,12 +15,12 @@ subject { described_class.new({ substitutions: instructions }.merge(additional_parameters)) } - let(:sample_a) { create :sample } - let(:sample_b) { create :sample } - let(:library_tube_a) { create :library_tube } - let(:library_tube_b) { create :library_tube } - let(:mx_library_tube) { create :multiplexed_library_tube } - let(:library_type) { create :library_type } + let(:sample_a) { create(:sample) } + let(:sample_b) { create(:sample) } + let(:library_tube_a) { create(:library_tube) } + let(:library_tube_b) { create(:library_tube) } + let(:mx_library_tube) { create(:multiplexed_library_tube) } + let(:library_type) { create(:library_type) } let(:additional_parameters) { {} } shared_examples 'tag substitution' do @@ -57,61 +57,71 @@ end context 'with a simple tag swap' do - let(:sample_a_orig_tag) { create :tag } - let(:sample_a_orig_tag2) { create :tag } + let(:sample_a_orig_tag) { create(:tag) } + let(:sample_a_orig_tag2) { create(:tag) } let(:sample_a_new_tag) { sample_b_orig_tag } - let(:sample_b_orig_tag) { create :tag } - let(:sample_b_orig_tag2) { create :tag } + let(:sample_b_orig_tag) { create(:tag) } + let(:sample_b_orig_tag2) { create(:tag) } let(:sample_b_new_tag) { sample_a_orig_tag } let!(:library_aliquot_a) do - create :aliquot, - sample: sample_a, - tag: sample_a_orig_tag, - tag2: sample_a_orig_tag2, - library: library_tube_a, - receptacle: library_tube_a + create( + :aliquot, + sample: sample_a, + tag: sample_a_orig_tag, + tag2: sample_a_orig_tag2, + library: library_tube_a, + receptacle: library_tube_a + ) end let!(:library_aliquot_b) do - create :aliquot, - sample: sample_b, - tag: sample_b_orig_tag, - tag2: sample_b_orig_tag2, - library: library_tube_b, - receptacle: library_tube_b + create( + :aliquot, + sample: sample_b, + tag: sample_b_orig_tag, + tag2: sample_b_orig_tag2, + library: library_tube_b, + receptacle: library_tube_b + ) end let!(:mx_aliquot_a) do - create :aliquot, - sample: sample_a, - tag: sample_a_orig_tag, - tag2: sample_a_orig_tag2, - library: library_tube_a, - receptacle: mx_library_tube + create( + :aliquot, + sample: sample_a, + tag: sample_a_orig_tag, + tag2: sample_a_orig_tag2, + library: library_tube_a, + receptacle: mx_library_tube + ) end let!(:mx_aliquot_b) do - create :aliquot, - sample: sample_b, - tag: sample_b_orig_tag, - tag2: sample_b_orig_tag2, - library: library_tube_b, - receptacle: mx_library_tube + create( + :aliquot, + sample: sample_b, + tag: sample_b_orig_tag, + tag2: sample_b_orig_tag2, + library: library_tube_b, + receptacle: mx_library_tube + ) end - let!(:mx_aliquot_c) { create :tagged_aliquot, library: library_tube_b, receptacle: mx_library_tube } + let!(:mx_aliquot_c) { create(:tagged_aliquot, library: library_tube_b, receptacle: mx_library_tube) } - let!(:lane) { create :lane } + let!(:lane) { create(:lane) } let!(:lane_aliquot_a) do - create :aliquot, - sample: sample_a, - tag: sample_a_orig_tag, - tag2: sample_a_orig_tag2, - library: library_tube_a, - receptacle: lane + create( + :aliquot, + sample: sample_a, + tag: sample_a_orig_tag, + tag2: sample_a_orig_tag2, + library: library_tube_a, + receptacle: lane + ) end let!(:flowcell_message) do batch = create(:sequencing_batch, request_attributes: [{ target_asset: lane }]) - create :flowcell_messenger, target: batch + create(:flowcell_messenger, target: batch) end context 'with only tag 1' do @@ -342,36 +352,36 @@ end context 'with a multi-tag sample tag swap' do - let(:sample_a_orig_tag_a) { create :tag } - let(:sample_b_orig_tag_a) { create :tag } - let(:sample_a_orig_tag_b) { create :tag } - let(:sample_b_orig_tag_b) { create :tag } - let(:other_tag) { create :tag } + let(:sample_a_orig_tag_a) { create(:tag) } + let(:sample_b_orig_tag_a) { create(:tag) } + let(:sample_a_orig_tag_b) { create(:tag) } + let(:sample_b_orig_tag_b) { create(:tag) } + let(:other_tag) { create(:tag) } # Build aliquots let!(:library_aliquot_a_a) do - create :aliquot, sample: sample_a, tag: sample_a_orig_tag_a, library: library_tube_a, receptacle: library_tube_a + create(:aliquot, sample: sample_a, tag: sample_a_orig_tag_a, library: library_tube_a, receptacle: library_tube_a) end let!(:library_aliquot_a_b) do - create :aliquot, sample: sample_a, tag: sample_a_orig_tag_b, library: library_tube_a, receptacle: library_tube_a + create(:aliquot, sample: sample_a, tag: sample_a_orig_tag_b, library: library_tube_a, receptacle: library_tube_a) end let!(:library_aliquot_b_a) do - create :aliquot, sample: sample_b, tag: sample_b_orig_tag_a, library: library_tube_b, receptacle: library_tube_b + create(:aliquot, sample: sample_b, tag: sample_b_orig_tag_a, library: library_tube_b, receptacle: library_tube_b) end let!(:library_aliquot_b_b) do - create :aliquot, sample: sample_b, tag: sample_b_orig_tag_b, library: library_tube_b, receptacle: library_tube_b + create(:aliquot, sample: sample_b, tag: sample_b_orig_tag_b, library: library_tube_b, receptacle: library_tube_b) end let!(:mx_aliquot_a_a) do - create :aliquot, sample: sample_a, tag: sample_a_orig_tag_a, library: library_tube_a, receptacle: mx_library_tube + create(:aliquot, sample: sample_a, tag: sample_a_orig_tag_a, library: library_tube_a, receptacle: mx_library_tube) end let!(:mx_aliquot_a_b) do - create :aliquot, sample: sample_a, tag: sample_a_orig_tag_b, library: library_tube_a, receptacle: mx_library_tube + create(:aliquot, sample: sample_a, tag: sample_a_orig_tag_b, library: library_tube_a, receptacle: mx_library_tube) end let!(:mx_aliquot_b_a) do - create :aliquot, sample: sample_b, tag: sample_b_orig_tag_a, library: library_tube_b, receptacle: mx_library_tube + create(:aliquot, sample: sample_b, tag: sample_b_orig_tag_a, library: library_tube_b, receptacle: mx_library_tube) end let!(:mx_aliquot_b_b) do - create :aliquot, sample: sample_b, tag: sample_b_orig_tag_b, library: library_tube_b, receptacle: mx_library_tube + create(:aliquot, sample: sample_b, tag: sample_b_orig_tag_b, library: library_tube_b, receptacle: mx_library_tube) end let(:instructions) do diff --git a/spec/models/tasks/cherrypick_task_spec.rb b/spec/models/tasks/cherrypick_task_spec.rb index e27499943b..887de3e81f 100644 --- a/spec/models/tasks/cherrypick_task_spec.rb +++ b/spec/models/tasks/cherrypick_task_spec.rb @@ -5,16 +5,16 @@ RSpec.configure { |c| c.include LabWhereClientHelper } RSpec.describe CherrypickTask do - let!(:plate) { create :plate_with_untagged_wells, sample_count: 4 } - let(:control_plate) { create :control_plate, sample_count: 2 } + let!(:plate) { create(:plate_with_untagged_wells, sample_count: 4) } + let(:control_plate) { create(:control_plate, sample_count: 2) } let(:requests) do plate.wells.in_column_major_order.map { |w| create(:cherrypick_request, asset: w, submission: submission) } end let(:template) { create(:plate_template, size: 6) } let(:robot) { instance_double('Robot', max_beds: 2) } # rubocop:todo RSpec/VerifiedDoubleReference - let(:purpose) { create :purpose } + let(:purpose) { create(:purpose) } let(:batch) { instance_double('Batch', id: 1235, requests: requests) } # rubocop:todo RSpec/VerifiedDoubleReference - let(:submission) { create :submission } + let(:submission) { create(:submission) } let(:wells_to_leave_free) { Rails.application.config.plate_default_control_wells_to_leave_free } def pick_without_request_id(plates) @@ -100,7 +100,7 @@ def requests_for_plate(plate) end describe '#pick_onto_partial_plate' do - let!(:partial_plate) { create :plate, size: 6 } + let!(:partial_plate) { create(:plate, size: 6) } before do partial_plate.wells.create! @@ -109,7 +109,7 @@ def requests_for_plate(plate) context 'with controls' do before do - requests.first.update(submission: submission) + requests.first.update(submission:) allow(requests.first).to receive(:batch).and_return(batch) end @@ -120,7 +120,7 @@ def requests_for_plate(plate) end let(:instance) { described_class.new } - let!(:plate) { create :plate_with_untagged_wells, sample_count: 2 } + let!(:plate) { create(:plate_with_untagged_wells, sample_count: 2) } let(:destinations) do [ [ @@ -148,7 +148,7 @@ def requests_for_plate(plate) end let(:instance) { described_class.new } - let!(:plate) { create :plate_with_untagged_wells, sample_count: 4 } + let!(:plate) { create(:plate_with_untagged_wells, sample_count: 4) } let(:destinations) do [ [ @@ -179,9 +179,9 @@ def requests_for_plate(plate) end describe '#build_plate_wells_from_requests' do - let!(:plate1) { create :plate_with_untagged_wells, sample_count: 4, name: 'plate1' } - let!(:plate2) { create :plate_with_untagged_wells, sample_count: 4, name: 'plate2' } - let!(:plate3) { create :plate_with_untagged_wells, sample_count: 4, name: 'plate3' } + let!(:plate1) { create(:plate_with_untagged_wells, sample_count: 4, name: 'plate1') } + let!(:plate2) { create(:plate_with_untagged_wells, sample_count: 4, name: 'plate2') } + let!(:plate3) { create(:plate_with_untagged_wells, sample_count: 4, name: 'plate3') } let(:plates) { [plate1, plate2, plate3] } let(:requests1) { requests_for_plate(plate1) } let(:requests2) { requests_for_plate(plate2) } diff --git a/spec/models/tasks/plate_template_task_spec.rb b/spec/models/tasks/plate_template_task_spec.rb index ca528ec5dd..7d18042cb0 100644 --- a/spec/models/tasks/plate_template_task_spec.rb +++ b/spec/models/tasks/plate_template_task_spec.rb @@ -5,7 +5,7 @@ # This is a very tangled test, as I'm hoping to unhook the current dependencies # so need to wrap it at its current level of messiness RSpec.describe PlateTemplateTask do - subject(:task) { create :plate_template_task } + subject(:task) { create(:plate_template_task) } let(:pipeline) { task.workflow.pipeline } let(:requests) do @@ -21,13 +21,13 @@ let(:plate_a_barcode_number) { '1' } let(:plate_b_barcode_number) { '2' } let(:plate_a) do - create :plate, barcode: "SQPD-#{plate_a_barcode_number}", well_count: 4, well_factory: :untagged_well + create(:plate, barcode: "SQPD-#{plate_a_barcode_number}", well_count: 4, well_factory: :untagged_well) end let(:plate_b) do - create :plate, barcode: "SQPD-#{plate_b_barcode_number}", well_count: 4, well_factory: :untagged_well + create(:plate, barcode: "SQPD-#{plate_b_barcode_number}", well_count: 4, well_factory: :untagged_well) end - let(:batch) { create :batch, requests: requests, pipeline: pipeline } + let(:batch) { create(:batch, requests:, pipeline:) } let(:request) { instance_double(ActionDispatch::Request, parameters: params) } let(:workflow) { pipeline.workflow } @@ -57,8 +57,8 @@ let(:file) { instance_double(ActionDispatch::Http::UploadedFile, 'blank?' => false, :read => payload) } - let(:workflow_controller) { instance_double(WorkflowsController, batch: batch) } - let(:user) { build :user } + let(:workflow_controller) { instance_double(WorkflowsController, batch:) } + let(:user) { build(:user) } describe '#render_task' do let(:workflow_controller) do diff --git a/spec/models/tasks/set_descriptors_handler/handler_spec.rb b/spec/models/tasks/set_descriptors_handler/handler_spec.rb index c8ebc7c2a9..816d97a1ec 100644 --- a/spec/models/tasks/set_descriptors_handler/handler_spec.rb +++ b/spec/models/tasks/set_descriptors_handler/handler_spec.rb @@ -5,12 +5,12 @@ # This is a very tangled test, as I'm hoping to unhook the current dependencies # so need to wrap it at its current level of messiness RSpec.describe Tasks::SetDescriptorsHandler::Handler do - subject(:handler) { described_class.new(controller: controller, params: params, task: task, user: user) } + subject(:handler) { described_class.new(controller:, params:, task:, user:) } - let(:batch) { create :batch, request_count: 1 } + let(:batch) { create(:batch, request_count: 1) } let(:request) { batch.requests.first } let(:controller) { instance_double(WorkflowsController) } - let(:user) { create :user } + let(:user) { create(:user) } let(:task) { instance_double(SetDescriptorsTask, name: 'Step 1', id: 1) } describe '#perform' do diff --git a/spec/models/transfer/between_plates_spec.rb b/spec/models/transfer/between_plates_spec.rb index 2520c6607e..b4c100911f 100644 --- a/spec/models/transfer/between_plates_spec.rb +++ b/spec/models/transfer/between_plates_spec.rb @@ -3,9 +3,9 @@ require 'rails_helper' describe Transfer::BetweenPlates do - let(:user) { create :user } - let(:source) { create :stock_plate, sample_count: 5, well_factory: :untagged_well } - let(:destination) { create :plate, well_count: 5, well_factory: :empty_well } + let(:user) { create(:user) } + let(:source) { create(:stock_plate, sample_count: 5, well_factory: :untagged_well) } + let(:destination) { create(:plate, well_count: 5, well_factory: :empty_well) } before do described_class.create!( diff --git a/spec/models/transfer/from_plate_to_tube_spec.rb b/spec/models/transfer/from_plate_to_tube_spec.rb index 1bfdd4e42a..983872a7f9 100644 --- a/spec/models/transfer/from_plate_to_tube_spec.rb +++ b/spec/models/transfer/from_plate_to_tube_spec.rb @@ -3,8 +3,8 @@ require 'rails_helper' describe Transfer::FromPlateToTube do - let(:transfer_without_transfers) { create :transfer_from_plate_to_tube } - let(:transfer_with_transfers) { create :transfer_from_plate_to_tube_with_transfers } + let(:transfer_without_transfers) { create(:transfer_from_plate_to_tube) } + let(:transfer_with_transfers) { create(:transfer_from_plate_to_tube_with_transfers) } it 'transfers all wells by default' do expect(transfer_without_transfers.transfers).to eq(%w[A1 B1 C1]) diff --git a/spec/models/transfer_request_collection_spec.rb b/spec/models/transfer_request_collection_spec.rb index e357ec1de5..2c08e6b35b 100644 --- a/spec/models/transfer_request_collection_spec.rb +++ b/spec/models/transfer_request_collection_spec.rb @@ -5,14 +5,12 @@ RSpec.describe TransferRequestCollection, :transfer_request_collection do subject { described_class.new(creation_attributes) } - let(:user) { create :user } - let(:asset) { create :tagged_well } - let(:target_asset) { create :empty_library_tube } + let(:user) { create(:user) } + let(:asset) { create(:tagged_well) } + let(:target_asset) { create(:empty_library_tube) } context 'with a single transfer' do - let(:creation_attributes) do - { user: user, transfer_requests_attributes: [{ asset: asset, target_asset: target_asset }] } - end + let(:creation_attributes) { { user: user, transfer_requests_attributes: [{ asset:, target_asset: }] } } context 'and no outer requests' do describe '#save' do @@ -35,8 +33,8 @@ end context 'and one outer request' do - let(:submission) { create :submission } - let!(:outer_request) { create :request, asset: asset, submission: submission } + let(:submission) { create(:submission) } + let!(:outer_request) { create(:request, asset:, submission:) } describe '#save' do let(:transfer_request) { subject.transfer_requests.first } @@ -58,10 +56,10 @@ end context 'and two outer requests' do - let(:submission_a) { create :submission } - let(:submission_b) { create :submission } - let!(:outer_request) { create :request, asset: asset, submission: submission_a } - let!(:other_outer_request) { create :request, asset: asset, submission: submission_b } + let(:submission_a) { create(:submission) } + let(:submission_b) { create(:submission) } + let!(:outer_request) { create(:request, asset: asset, submission: submission_a) } + let!(:other_outer_request) { create(:request, asset: asset, submission: submission_b) } describe '#save' do let(:transfer_request) { subject.transfer_requests.first } @@ -102,9 +100,9 @@ end context 'and two outer requests in the same submission' do - let(:submission) { create :submission } - let!(:outer_request) { create :request, asset: asset, submission: submission } - let!(:other_outer_request) { create :request, asset: asset, submission: submission } + let(:submission) { create(:submission) } + let!(:outer_request) { create(:request, asset:, submission:) } + let!(:other_outer_request) { create(:request, asset:, submission:) } describe '#save' do let(:transfer_request) { subject.transfer_requests.first } @@ -126,10 +124,7 @@ context 'specifying outer_request' do let(:creation_attributes) do - { - user: user, - transfer_requests_attributes: [{ asset: asset, target_asset: target_asset, outer_request: outer_request }] - } + { user: user, transfer_requests_attributes: [{ asset:, target_asset:, outer_request: }] } end before { expect(subject.save).to be true } diff --git a/spec/models/transfer_request_spec.rb b/spec/models/transfer_request_spec.rb index 662d6d9d02..452b9d5167 100644 --- a/spec/models/transfer_request_spec.rb +++ b/spec/models/transfer_request_spec.rb @@ -4,32 +4,36 @@ require 'shared_contexts/limber_shared_context' RSpec.describe TransferRequest do - let(:source) { create :well_with_sample_and_without_plate } + let(:source) { create(:well_with_sample_and_without_plate) } let(:tag) { create(:tag).tag!(source) } - let(:destination) { create :well } - let(:example_study) { create :study } - let(:example_project) { create :project } + let(:destination) { create(:well) } + let(:example_study) { create(:study) } + let(:example_project) { create(:project) } context 'with a library request' do subject do - create :transfer_request, asset: source, target_asset: destination, submission: library_request.submission + create(:transfer_request, asset: source, target_asset: destination, submission: library_request.submission) end let(:library_request) do - create :library_request, - asset: source, - initial_study: example_study, - initial_project: example_project, - state: library_state + create( + :library_request, + asset: source, + initial_study: example_study, + initial_project: example_project, + state: library_state + ) end context 'with volume' do subject do - create :transfer_request, - asset: source, - target_asset: destination, - submission: library_request.submission, - volume: 4.5 + create( + :transfer_request, + asset: source, + target_asset: destination, + submission: library_request.submission, + volume: 4.5 + ) end let(:library_state) { 'pending' } @@ -68,11 +72,13 @@ context 'with a primer panel' do let(:library_request) do - create :gbs_request, - state: 'pending', - asset: source, - initial_study: example_study, - initial_project: example_project + create( + :gbs_request, + state: 'pending', + asset: source, + initial_study: example_study, + initial_project: example_project + ) end it 'sets appropriate metadata on the aliquots' do @@ -94,7 +100,7 @@ end context 'with multiple library requests' do - subject { create :transfer_request, asset: source, target_asset: destination, outer_request: library_request } + subject { create(:transfer_request, asset: source, target_asset: destination, outer_request: library_request) } before do library_request @@ -102,20 +108,24 @@ end let(:library_request) do - create :library_request, - asset: source, - initial_study: example_study, - initial_project: example_project, - state: library_state + create( + :library_request, + asset: source, + initial_study: example_study, + initial_project: example_project, + state: library_state + ) end let(:dummy_library_request) do - create :library_request, - asset: source, - initial_study: example_study, - initial_project: example_project, - state: library_state, - submission: library_request.submission + create( + :library_request, + asset: source, + initial_study: example_study, + initial_project: example_project, + state: library_state, + submission: library_request.submission + ) end context 'with a pending library request' do @@ -168,7 +178,7 @@ end context 'when the source has stock wells' do - let(:source) { create :well_with_sample_and_without_plate, stock_wells: create_list(:well, 2) } + let(:source) { create(:well_with_sample_and_without_plate, stock_wells: create_list(:well, 2)) } it 'sets the stock wells' do expect(destination.stock_wells).to eq(source.stock_wells) @@ -176,7 +186,7 @@ end context 'when the source is a stock well' do - let(:source) { create :well_with_sample_and_without_plate, plate: create(:stock_plate) } + let(:source) { create(:well_with_sample_and_without_plate, plate: create(:stock_plate)) } it 'sets the stock wells' do expect(destination.stock_wells).to eq([source]) @@ -214,7 +224,7 @@ context 'when the destination has equivalent aliquots' do let(:equivalent_aliquot) { source.aliquots.first.dup } - let(:destination) { create :well, aliquots: [equivalent_aliquot] } + let(:destination) { create(:well, aliquots: [equivalent_aliquot]) } let(:transfer_request) do described_class.new(asset: source, target_asset: destination, merge_equivalent_aliquots: merge) end @@ -245,11 +255,11 @@ end context 'with a tag clash' do - let!(:tag) { create :tag } - let!(:tag2) { create :tag } - let!(:aliquot_1) { create :aliquot, tag: tag, tag2: tag2 } - let!(:aliquot_2) { create :aliquot, tag: tag, tag2: tag2, receptacle: create(:well) } - let!(:target_asset) { create :well, aliquots: [aliquot_1] } + let!(:tag) { create(:tag) } + let!(:tag2) { create(:tag) } + let!(:aliquot_1) { create(:aliquot, tag:, tag2:) } + let!(:aliquot_2) { create(:aliquot, tag: tag, tag2: tag2, receptacle: create(:well)) } + let!(:target_asset) { create(:well, aliquots: [aliquot_1]) } it 'raises an exception' do expect do @@ -260,7 +270,7 @@ end describe 'state_machine' do - subject { create :transfer_request } + subject { create(:transfer_request) } { start: { @@ -316,7 +326,7 @@ end (%i[pending started passed failed qc_complete cancelled] - transitions.keys).each do |state| it "does not allow #{state} requests to #{event}" do - tf = build :transfer_request, state: state + tf = build(:transfer_request, state:) expect(tf).not_to allow_event(event) end end @@ -324,20 +334,20 @@ end context 'outer request' do - let(:last_well) { create :well_with_sample_and_without_plate } - let(:example_study) { create :study } - let(:example_project) { create :project } + let(:last_well) { create(:well_with_sample_and_without_plate) } + let(:example_study) { create(:study) } + let(:example_project) { create(:project) } - let(:library_request) { create :library_request, asset: stock_asset, submission: create(:submission) } + let(:library_request) { create(:library_request, asset: stock_asset, submission: create(:submission)) } before do # A decoy library request, this is part of a different submission and # should be ignored - create :library_request, asset: stock_asset, submission: create(:submission) + create(:library_request, asset: stock_asset, submission: create(:submission)) last_well.stock_wells << stock_asset end - let(:transfer_request) { create :transfer_request, asset: source_asset, submission: library_request.submission } + let(:transfer_request) { create(:transfer_request, asset: source_asset, submission: library_request.submission) } describe '#outer_request' do subject { transfer_request.outer_request } @@ -351,17 +361,22 @@ context 'from a well downstream of a stock asset' do let(:source_asset) { last_well } - let(:stock_asset) { create :well_with_sample_and_without_plate } + let(:stock_asset) { create(:well_with_sample_and_without_plate) } it { is_expected.to eq library_request } end context 'from a tube made from the last well' do - let(:stock_asset) { create :well_with_sample_and_without_plate } - let(:source_asset) { create :tube } + let(:stock_asset) { create(:well_with_sample_and_without_plate) } + let(:source_asset) { create(:tube) } before do - create :transfer_request, asset: last_well, target_asset: source_asset, submission: library_request.submission + create( + :transfer_request, + asset: last_well, + target_asset: source_asset, + submission: library_request.submission + ) end it { is_expected.to eq library_request } @@ -409,7 +424,7 @@ context 'when any of the downstream assets have a batch' do let(:batch) { create(:sequencing_batch, request_count: 1) } - before { outer_requests_graph[2].update(batch: batch) } + before { outer_requests_graph[2].update(batch:) } it 'does not remove the downstream aliquots' do expect { transfer_requests.first.fail! }.not_to change { @@ -433,56 +448,66 @@ end context 'transfer downstream of pooling (such as in ISC)' do - let(:library_request_type) { create :library_request_type } - let(:multiplex_request_type) { create :multiplex_request_type } + let(:library_request_type) { create(:library_request_type) } + let(:multiplex_request_type) { create(:multiplex_request_type) } # In some cases (such as chromium) we have multiple aliquots pre library request - let(:source_well_a) { create :tagged_well, aliquot_count: 2 } - let(:source_well_b) { create :tagged_well } - let(:target_well) { create :empty_well } - let(:submission) { create :submission } + let(:source_well_a) { create(:tagged_well, aliquot_count: 2) } + let(:source_well_b) { create(:tagged_well) } + let(:target_well) { create(:empty_well) } + let(:submission) { create(:submission) } let(:order) do - create :library_order, - submission: submission, - request_types: [library_request_type.id, multiplex_request_type.id], - assets: [source_well_a, source_well_b] + create( + :library_order, + submission: submission, + request_types: [library_request_type.id, multiplex_request_type.id], + assets: [source_well_a, source_well_b] + ) end - let(:multiplexed_library_tube) { create :multiplexed_library_tube, aliquots: [] } + let(:multiplexed_library_tube) { create(:multiplexed_library_tube, aliquots: []) } let(:library_request_a) do - create :library_request, - asset: source_well_a, - target_asset: target_well, - submission: submission, - order: order, - state: 'passed', - request_type: library_request_type + create( + :library_request, + asset: source_well_a, + target_asset: target_well, + submission: submission, + order: order, + state: 'passed', + request_type: library_request_type + ) end let(:library_request_b) do - create :library_request, - asset: source_well_b, - target_asset: target_well, - submission: submission, - order: order, - state: 'passed', - request_type: library_request_type + create( + :library_request, + asset: source_well_b, + target_asset: target_well, + submission: submission, + order: order, + state: 'passed', + request_type: library_request_type + ) end # While source and target assets are the same, we actually have two requests let(:multiplex_request_a) do - create :multiplex_request, - asset: target_well, - target_asset: multiplexed_library_tube, - submission: submission, - order: order, - request_type: multiplex_request_type + create( + :multiplex_request, + asset: target_well, + target_asset: multiplexed_library_tube, + submission: submission, + order: order, + request_type: multiplex_request_type + ) end let(:multiplex_request_b) do - create :multiplex_request, - asset: target_well, - target_asset: multiplexed_library_tube, - submission: submission, - order: order, - request_type: multiplex_request_type + create( + :multiplex_request, + asset: target_well, + target_asset: multiplexed_library_tube, + submission: submission, + order: order, + request_type: multiplex_request_type + ) end # Order here matters @@ -492,12 +517,12 @@ library_request_b multiplex_request_a multiplex_request_b - create :transfer_request, asset: source_well_a, target_asset: target_well, submission: submission - create :transfer_request, asset: source_well_b, target_asset: target_well, submission: submission + create(:transfer_request, asset: source_well_a, target_asset: target_well, submission: submission) + create(:transfer_request, asset: source_well_b, target_asset: target_well, submission: submission) end it 'associated each aliquot with a different library request' do - create :transfer_request, asset: target_well, target_asset: multiplexed_library_tube, submission: submission + create(:transfer_request, asset: target_well, target_asset: multiplexed_library_tube, submission: submission) expect(multiplexed_library_tube.reload.aliquots.map(&:request_id)).to eq( [multiplex_request_a.id, multiplex_request_a.id, multiplex_request_b.id] ) diff --git a/spec/models/tube_purpose_spec.rb b/spec/models/tube_purpose_spec.rb index 4284e66a31..f6b322fac7 100644 --- a/spec/models/tube_purpose_spec.rb +++ b/spec/models/tube_purpose_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' describe Tube::Purpose do - let(:tube_purpose) { create :tube_purpose, prefix: barcode_prefix, target_type: target_type } + let(:tube_purpose) { create(:tube_purpose, prefix: barcode_prefix, target_type: target_type) } shared_examples 'a tube factory' do describe '#create!' do diff --git a/spec/models/tube_rack_spec.rb b/spec/models/tube_rack_spec.rb index 2e10216e4b..f89b4b5238 100644 --- a/spec/models/tube_rack_spec.rb +++ b/spec/models/tube_rack_spec.rb @@ -4,21 +4,21 @@ RSpec.describe TubeRack do describe '#create' do it 'can be created' do - tube_rack = create :tube_rack + tube_rack = create(:tube_rack) expect(described_class.exists?(tube_rack.id)).to be(true) end it 'can contain racked_tubes' do - tube_rack = create :tube_rack - racked_tube = create :racked_tube + tube_rack = create(:tube_rack) + racked_tube = create(:racked_tube) expect { tube_rack.racked_tubes << racked_tube }.to(change { tube_rack.racked_tubes.count }.by(1)) end it 'can contain a barcode' do - tube_rack = create :tube_rack - barcode = create :barcode, barcode: 'SA00057843' + tube_rack = create(:tube_rack) + barcode = create(:barcode, barcode: 'SA00057843') tube_rack.barcodes << barcode @@ -28,7 +28,7 @@ describe '#update' do it 'can be updated' do - tube_rack = create :tube_rack + tube_rack = create(:tube_rack) tube_rack.update(size: 96) expect(described_class.find(tube_rack.id).size).to eq(96) @@ -36,7 +36,7 @@ end describe '#destroy' do - let!(:tube_rack) { create :tube_rack } + let!(:tube_rack) { create(:tube_rack) } it 'can be destroyed' do tube_rack.destroy @@ -57,9 +57,9 @@ describe 'scope #contained_samples' do let(:num_tubes) { locations.length } - let(:tube_rack) { create :tube_rack } + let(:tube_rack) { create(:tube_rack) } let(:locations) { %w[A01 B01 C01] } - let(:barcodes) { Array.new(num_tubes) { create :fluidx } } + let(:barcodes) { Array.new(num_tubes) { create(:fluidx) } } let!(:tubes) do Array.new(num_tubes) do |i| create(:sample_tube, :in_a_rack, tube_rack: tube_rack, coordinate: locations[i], barcodes: [barcodes[i]]) @@ -72,20 +72,20 @@ end context 'with a rack with tubes and requests' do - let(:tube_rack) { create :tube_rack } - let(:tube_a) { create :tube, :in_a_rack, tube_rack: tube_rack, coordinate: 'A1' } - let(:tube_b) { create :tube, :in_a_rack, tube_rack: tube_rack, coordinate: 'H12' } - let(:aliquot) { create :aliquot, receptacle: tube_a.receptacle, request: create(:request, submission: submission) } - let(:outer_request) { create :request, asset: tube_b.receptacle, submission: submission } - let(:submission) { create :submission } + let(:tube_rack) { create(:tube_rack) } + let(:tube_a) { create(:tube, :in_a_rack, tube_rack: tube_rack, coordinate: 'A1') } + let(:tube_b) { create(:tube, :in_a_rack, tube_rack: tube_rack, coordinate: 'H12') } + let(:aliquot) { create(:aliquot, receptacle: tube_a.receptacle, request: create(:request, submission:)) } + let(:outer_request) { create(:request, asset: tube_b.receptacle, submission: submission) } + let(:submission) { create(:submission) } # The comments scope should also retrieve comments associated with tubes, and # their requests describe '#comments' do - let!(:rack_comment) { create :comment, commentable: tube_rack, title: 'Rack' } - let!(:tube_comment) { create :comment, commentable: tube_a, title: 'Tube' } - let!(:request_comment_a) { create :comment, commentable: aliquot.request, title: 'Request(Aliquot)' } - let!(:request_comment_b) { create :comment, commentable: outer_request, title: 'Request(Receptacle)' } + let!(:rack_comment) { create(:comment, commentable: tube_rack, title: 'Rack') } + let!(:tube_comment) { create(:comment, commentable: tube_a, title: 'Tube') } + let!(:request_comment_a) { create(:comment, commentable: aliquot.request, title: 'Request(Aliquot)') } + let!(:request_comment_b) { create(:comment, commentable: outer_request, title: 'Request(Receptacle)') } it 'includes all relevant comments' do comments = tube_rack.reload.comments @@ -105,7 +105,7 @@ before { outer_request } it 'ensures comments are visible on the tubes' do - create :comment, commentable: tube_rack + create(:comment, commentable: tube_rack) expect(tube_b.reload.comments.count).to eq 1 end end @@ -114,7 +114,7 @@ before { tube_b } it 'ensures comments are visible on the tubes' do - create :comment, commentable: tube_rack + create(:comment, commentable: tube_rack) expect(tube_b.reload.comments.count).to eq 1 end end diff --git a/spec/models/tube_spec.rb b/spec/models/tube_spec.rb index 7e3643c426..c00baca3f6 100644 --- a/spec/models/tube_spec.rb +++ b/spec/models/tube_spec.rb @@ -5,10 +5,10 @@ describe Tube do describe 'scope:: in_column_major_order' do - let(:tube_rack) { create :tube_rack } + let(:tube_rack) { create(:tube_rack) } let(:num_tubes) { locations.length } let(:locations) { %w[A01 H12 D04] } - let(:barcodes) { Array.new(num_tubes) { create :fluidx } } + let(:barcodes) { Array.new(num_tubes) { create(:fluidx) } } before do Array.new(num_tubes) do |i| @@ -22,7 +22,7 @@ end context 'when a tube is not in a rack' do - let!(:tube) { create :tube } + let!(:tube) { create(:tube) } it 'returns nil for the tube_rack relation' do expect(tube.tube_rack).to be_nil @@ -30,8 +30,8 @@ end context 'when a tube is in a rack' do - let!(:tube_rack) { create :tube_rack } - let!(:tube) { create :tube } + let!(:tube_rack) { create(:tube_rack) } + let!(:tube) { create(:tube) } let!(:racked_tube) { RackedTube.create(tube_rack_id: tube_rack.id, tube_id: tube.id) } it 'destroying the Tube destroys the RackedTube too, but not the TubeRack' do @@ -68,9 +68,9 @@ end describe '#comments' do - let(:tube) { create :tube } + let(:tube) { create(:tube) } - before { create :comment, commentable: tube, description: 'Comment on tube' } + before { create(:comment, commentable: tube, description: 'Comment on tube') } it 'allows comment addition' do tube.comments.create!(description: 'Works') @@ -86,11 +86,11 @@ end context 'with requests' do - let(:submission) { create :submission } - let!(:request) { create :well_request, asset: tube, submission: submission } + let(:submission) { create(:submission) } + let!(:request) { create(:well_request, asset: tube, submission: submission) } before do - create :comment, commentable: request, description: 'Comment on request' + create(:comment, commentable: request, description: 'Comment on request') tube.reload end @@ -110,11 +110,11 @@ context 'with requests in progress the wells' do before do - submission = create :submission - request = create :well_request, submission: submission - tube.receptacle.aliquots << create(:aliquot, request: request) - create :transfer_request, target_asset: tube, submission: submission - create :comment, commentable: request, description: 'Comment on request' + submission = create(:submission) + request = create(:well_request, submission:) + tube.receptacle.aliquots << create(:aliquot, request:) + create(:transfer_request, target_asset: tube, submission: submission) + create(:comment, commentable: request, description: 'Comment on request') tube.reload end @@ -127,12 +127,12 @@ context 'with multiple identical comments' do before do - submission = create :submission - request = create :well_request, asset: tube, submission: submission - request2 = create :well_request, asset: tube, submission: submission - create :comment, commentable: request, description: 'Duplicate comment' - create :comment, commentable: request2, description: 'Duplicate comment' - create :comment, commentable: tube, description: 'Duplicate comment' + submission = create(:submission) + request = create(:well_request, asset: tube, submission: submission) + request2 = create(:well_request, asset: tube, submission: submission) + create(:comment, commentable: request, description: 'Duplicate comment') + create(:comment, commentable: request2, description: 'Duplicate comment') + create(:comment, commentable: tube, description: 'Duplicate comment') tube.reload end diff --git a/spec/models/user_query_spec.rb b/spec/models/user_query_spec.rb index 95b9aa19a7..af3005ce6f 100644 --- a/spec/models/user_query_spec.rb +++ b/spec/models/user_query_spec.rb @@ -4,7 +4,7 @@ require 'timecop' describe UserQuery do - let!(:user) { create :user, login: 'login', email: 'login@example.com' } + let!(:user) { create(:user, login: 'login', email: 'login@example.com') } let!(:user_query_attributes) do { user_email: 'another_email@example.com', diff --git a/spec/models/user_spec.rb b/spec/models/user_spec.rb index c7c3b1632e..9772a60032 100644 --- a/spec/models/user_spec.rb +++ b/spec/models/user_spec.rb @@ -3,10 +3,10 @@ require 'rails_helper' RSpec.describe User do - let(:user) { create :user } + let(:user) { create(:user) } describe '#consent_withdrawn_sample_metadata' do - let(:samples) { create_list :sample, 4 } + let(:samples) { create_list(:sample, 4) } before { samples.each { |sample| sample.sample_metadata.update(user_id_of_consent_withdrawn: user.id) } } @@ -17,7 +17,7 @@ shared_examples 'a role predicate' do context 'when checking an administrator is an administrator' do - let(:user) { create :admin } + let(:user) { create(:admin) } let(:role_name) { 'administrator' } let(:authorizable) { nil } @@ -25,7 +25,7 @@ end context 'when checking an administrator is an manager' do - let(:user) { create :admin } + let(:user) { create(:admin) } let(:role_name) { 'manager' } let(:authorizable) { nil } @@ -33,7 +33,7 @@ end context 'when checking an non-administrator is an administrator' do - let(:user) { create :user } + let(:user) { create(:user) } let(:role_name) { 'administrator' } let(:authorizable) { nil } @@ -41,7 +41,7 @@ end context 'when checking an manager is an manager (generic)' do - let(:study) { create :study_with_manager } + let(:study) { create(:study_with_manager) } let(:user) { study.managers.first } let(:role_name) { 'manager' } let(:authorizable) { nil } @@ -50,7 +50,7 @@ end context 'when checking an manager of their study' do - let(:study) { create :study_with_manager } + let(:study) { create(:study_with_manager) } let(:user) { study.managers.first } let(:role_name) { 'manager' } let(:authorizable) { study } @@ -59,10 +59,10 @@ end context 'when checking an manager of a different study' do - let(:study) { create :study_with_manager } + let(:study) { create(:study_with_manager) } let(:user) { study.managers.first } let(:role_name) { 'manager' } - let(:authorizable) { create :study } + let(:authorizable) { create(:study) } it { is_expected.to be false } end @@ -98,8 +98,8 @@ end describe '#grant_role' do - let(:user) { create :user } - let(:study) { create :study } + let(:user) { create(:user) } + let(:study) { create(:study) } it 'adds a role to a user' do user.grant_role('administrator') @@ -127,7 +127,7 @@ end describe '#remove_role' do - let(:study) { create :study_with_manager, updated_at: 2.years.ago } + let(:study) { create(:study_with_manager, updated_at: 2.years.ago) } it 'updates the study updated_at timestamp' do # We make sure that defining a study with a manager triggers study update diff --git a/spec/models/well_attribute_spec.rb b/spec/models/well_attribute_spec.rb index d09f8755e9..9fbc043992 100644 --- a/spec/models/well_attribute_spec.rb +++ b/spec/models/well_attribute_spec.rb @@ -3,8 +3,8 @@ require 'rails_helper' describe WellAttribute do - let(:well_attribute) { create :well_attribute } - let(:well) { create :well, well_attribute: well_attribute } + let(:well_attribute) { create(:well_attribute) } + let(:well) { create(:well, well_attribute:) } let!(:warehouse_message) { Messenger.create!(target: well, template: 'WellStockResourceIO', root: 'stock_resource') } it 'does not let current_volume to get negative' do diff --git a/spec/models/well_spec.rb b/spec/models/well_spec.rb index 2cd6989c94..826afa93be 100644 --- a/spec/models/well_spec.rb +++ b/spec/models/well_spec.rb @@ -3,7 +3,7 @@ require 'timecop' describe Well do - subject(:well) { create :well, well_attribute_attributes: well_attributes } + subject(:well) { create(:well, well_attribute_attributes: well_attributes) } let(:well_attributes) { {} } @@ -73,7 +73,7 @@ describe '#update_from_qc' do let(:well_attributes) { { concentration: nil } } - let(:qc_result) { build :qc_result, key: key, value: value, units: units, assay_type: 'assay', assay_version: 1 } + let(:qc_result) { build(:qc_result, key: key, value: value, units: units, assay_type: 'assay', assay_version: 1) } before { well.update_from_qc(qc_result) } @@ -159,10 +159,10 @@ end it 'return a correct hash of target wells' do - purposes = create_list :plate_purpose, 4 - stock_plate = create :plate_with_untagged_wells, sample_count: 3 + purposes = create_list(:plate_purpose, 4) + stock_plate = create(:plate_with_untagged_wells, sample_count: 3) - norm_plates = purposes.map { |purpose| create :plate_with_untagged_wells, purpose: purpose, sample_count: 3 } + norm_plates = purposes.map { |purpose| create(:plate_with_untagged_wells, purpose: purpose, sample_count: 3) } well_plate_concentrations = [ # Plate 1, Plate 2, Plate 3 @@ -242,7 +242,7 @@ context 'with a plate' do before do - @plate = create :plate + @plate = create(:plate) well.plate = @plate end @@ -277,8 +277,8 @@ # rubocop:enable Metrics/ParameterLists context 'cherrypick by nano grams' do before do - @source_well = create :well - @target_well = create :well + @source_well = create(:well) + @target_well = create(:well) minimum_volume = 10 maximum_volume = 50 robot_minimum_picking_volume = 1.0 @@ -314,8 +314,8 @@ context 'when while cherrypicking by nanograms' do context 'and we want to get less volume than the minimum' do before do - @source_well = create :well - @target_well = create :well + @source_well = create(:well) + @target_well = create(:well) @measured_concentration = 100 @measured_volume = 50 @@ -470,35 +470,41 @@ context 'proceed test' do before do - @our_product_criteria = create :product_criteria - @other_criteria = create :product_criteria + @our_product_criteria = create(:product_criteria) + @other_criteria = create(:product_criteria) @old_report = - create :qc_report, - product_criteria: @our_product_criteria, - created_at: 1.day.ago, - report_identifier: "A#{Time.zone.now}" + create( + :qc_report, + product_criteria: @our_product_criteria, + created_at: 1.day.ago, + report_identifier: "A#{Time.zone.now}" + ) @current_report = - create :qc_report, - product_criteria: @our_product_criteria, - created_at: 1.hour.ago, - report_identifier: "B#{Time.zone.now}" + create( + :qc_report, + product_criteria: @our_product_criteria, + created_at: 1.hour.ago, + report_identifier: "B#{Time.zone.now}" + ) @unrelated_report = - create :qc_report, - product_criteria: @other_criteria, - created_at: Time.zone.now, - report_identifier: "C#{Time.zone.now}" + create( + :qc_report, + product_criteria: @other_criteria, + created_at: Time.zone.now, + report_identifier: "C#{Time.zone.now}" + ) - @stock_well = create :well + @stock_well = create(:well) well.stock_wells.attach!([@stock_well]) well.reload - create :qc_metric, asset: @stock_well, qc_report: @old_report, qc_decision: 'passed', proceed: true - create :qc_metric, asset: @stock_well, qc_report: @unrelated_report, qc_decision: 'passed', proceed: true + create(:qc_metric, asset: @stock_well, qc_report: @old_report, qc_decision: 'passed', proceed: true) + create(:qc_metric, asset: @stock_well, qc_report: @unrelated_report, qc_decision: 'passed', proceed: true) @expected_metric = - create :qc_metric, asset: @stock_well, qc_report: @current_report, qc_decision: 'failed', proceed: true + create(:qc_metric, asset: @stock_well, qc_report: @current_report, qc_decision: 'failed', proceed: true) end it 'report appropriate metrics' do @@ -524,7 +530,7 @@ build(:qc_result_molarity), build(:qc_result_rin) ] - well = create(:well, qc_results: qc_results) + well = create(:well, qc_results:) expect(well.qc_results_by_key.size).to eq(4) expect(well.qc_results_by_key['concentration'].length).to eq(1) end @@ -566,7 +572,7 @@ end context '(DPL-148) on updating well attribute' do - let(:well) { create :well } + let(:well) { create(:well) } it 'triggers warehouse update', :warren do expect do diff --git a/spec/models/work_completion_spec.rb b/spec/models/work_completion_spec.rb index dd84c0fefb..6b43c7cec0 100644 --- a/spec/models/work_completion_spec.rb +++ b/spec/models/work_completion_spec.rb @@ -15,16 +15,16 @@ let(:submission_request_types) { [library_request_type] } let(:target_tube) do - tt = create :multiplexed_library_tube + tt = create(:multiplexed_library_tube) tt.parents << upstream_tube - create :transfer_request, asset: upstream_tube, target_asset: tt + create(:transfer_request, asset: upstream_tube, target_asset: tt) tt end let(:upstream_tube) do - ut = create :new_stock_multiplexed_library_tube + ut = create(:new_stock_multiplexed_library_tube) [target_plate, target_plate2].each do |plate| - plate.wells.each { |well| create :transfer_request, asset: well, target_asset: ut } + plate.wells.each { |well| create(:transfer_request, asset: well, target_asset: ut) } end ut.parents = [target_plate, target_plate2] ut @@ -32,22 +32,24 @@ let(:target_plate2) do build_library_requests2 - create :target_plate, parent: input_plate2, well_count: tested_wells, submission: target_submission2 + create(:target_plate, parent: input_plate2, well_count: tested_wells, submission: target_submission2) end - let(:input_plate2) { create :input_plate, well_count: tested_wells, well_factory: :tagged_well } + let(:input_plate2) { create(:input_plate, well_count: tested_wells, well_factory: :tagged_well) } let(:build_library_requests2) do input_plate2.wells.each do |well| - create_list :library_request, - requests_per_well, - request_type: library_request_type, - asset: well, - submission: target_submission2, - state: 'started', - order: order2 + create_list( + :library_request, + requests_per_well, + request_type: library_request_type, + asset: well, + submission: target_submission2, + state: 'started', + order: order2 + ) end end let(:target_submission2) do - create :library_submission, assets: input_plate2.wells, request_types: submission_request_types + create(:library_submission, assets: input_plate2.wells, request_types: submission_request_types) end let(:order2) { target_submission2.orders.first } diff --git a/spec/models/work_order_spec.rb b/spec/models/work_order_spec.rb index 8f813399cc..d349924266 100644 --- a/spec/models/work_order_spec.rb +++ b/spec/models/work_order_spec.rb @@ -3,10 +3,10 @@ require 'rails_helper' describe WorkOrder do - subject { build :work_order, work_order_type: work_order_type } + subject { build(:work_order, work_order_type:) } context 'with a work_order_type' do - let(:work_order_type) { create :work_order_type } + let(:work_order_type) { create(:work_order_type) } it { is_expected.to be_valid } end @@ -19,7 +19,7 @@ context 'with requests' do let(:requests) { build_list(:request, 2) } - let(:work_order) { build :work_order, requests: requests } + let(:work_order) { build(:work_order, requests:) } describe '#state=' do before { work_order.state = 'passed' } @@ -33,8 +33,8 @@ describe WorkOrder::Factory do subject(:factory) { described_class.new(submission) } - let(:submission) { create :submission, requests: requests } - let(:request_type) { create :request_type } + let(:submission) { create(:submission, requests:) } + let(:request_type) { create(:request_type) } let(:requests_set_a) { create_list(:request, 3, asset: create(:well), request_type: request_type) } let(:requests) { requests_set_a + requests_set_b } diff --git a/spec/models/work_order_type_spec.rb b/spec/models/work_order_type_spec.rb index 2e6bd39805..fe8fe8c869 100644 --- a/spec/models/work_order_type_spec.rb +++ b/spec/models/work_order_type_spec.rb @@ -3,7 +3,7 @@ require 'rails_helper' describe WorkOrderType do - subject { build :work_order_type, name: name } + subject { build(:work_order_type, name:) } context 'with a name' do let(:name) { 'test_order' } @@ -13,7 +13,7 @@ end context 'which already exists' do - before { create :work_order_type, name: name } + before { create(:work_order_type, name:) } it { is_expected.not_to be_valid } end diff --git a/spec/models/working_dilution_plate_spec.rb b/spec/models/working_dilution_plate_spec.rb index 01b53bab83..45bf75e8a6 100644 --- a/spec/models/working_dilution_plate_spec.rb +++ b/spec/models/working_dilution_plate_spec.rb @@ -22,9 +22,9 @@ } end let(:plate) do - create :working_dilution_plate, well_count: 3, well_factory: :empty_well, parents: [parent], dilution_factor: 10 + create(:working_dilution_plate, well_count: 3, well_factory: :empty_well, parents: [parent], dilution_factor: 10) end - let(:parent) { create :plate, well_count: 3 } + let(:parent) { create(:plate, well_count: 3) } let(:parser) { MockParser.new(readings) } before { plate.update_qc_values_with_parser(parser) } diff --git a/spec/rails_helper.rb b/spec/rails_helper.rb index 4c85f7ed6a..cf90c377a2 100644 --- a/spec/rails_helper.rb +++ b/spec/rails_helper.rb @@ -84,6 +84,7 @@ config.include Rails.application.routes.url_helpers config.include ApiV2Helper, with: :api_v2 + config.include ApiV2Matchers config.include RSpec::Longrun::DSL Capybara.add_selector(:data_behavior) { xpath { |name| XPath.css("[data-behavior='#{name}']") } } diff --git a/spec/requests/api/v2/aliquots_spec.rb b/spec/requests/api/v2/aliquots_spec.rb index 614ae9290c..9708bb64bd 100644 --- a/spec/requests/api/v2/aliquots_spec.rb +++ b/spec/requests/api/v2/aliquots_spec.rb @@ -25,7 +25,7 @@ end context 'with a aliquot' do - let(:resource_model) { create :aliquot } + let(:resource_model) { create(:aliquot) } it 'sends an individual aliquot' do api_get "#{base_endpoint}/#{resource_model.id}" diff --git a/spec/requests/api/v2/asset_audits_spec.rb b/spec/requests/api/v2/asset_audits_spec.rb index b00e71e203..82a81b0add 100644 --- a/spec/requests/api/v2/asset_audits_spec.rb +++ b/spec/requests/api/v2/asset_audits_spec.rb @@ -51,7 +51,7 @@ end describe '#post' do - let(:labware) { create :labware } + let(:labware) { create(:labware) } let(:payload) do { diff --git a/spec/requests/api/v2/bait_library_layouts_spec.rb b/spec/requests/api/v2/bait_library_layouts_spec.rb new file mode 100644 index 0000000000..8ff389389a --- /dev/null +++ b/spec/requests/api/v2/bait_library_layouts_spec.rb @@ -0,0 +1,421 @@ +# frozen_string_literal: true + +require 'rails_helper' +require './spec/requests/api/v2/shared_examples/api_key_authenticatable' +require './spec/requests/api/v2/shared_examples/post_requests' + +describe 'Bait Library Layouts API', with: :api_v2 do + let(:model_class) { BaitLibraryLayout } + + let(:base_endpoint) { "/api/v2/#{resource_type}" } + let(:resource_type) { model_class.name.demodulize.pluralize.underscore } + + it_behaves_like 'ApiKeyAuthenticatable' + + context 'with a list of resources' do + let(:resource_count) { 5 } + + before { create_list(:bait_library_layout, resource_count) } + + describe '#GET all the resources' do + before { api_get base_endpoint } + + it 'responds with a success http code' do + expect(response).to have_http_status(:success) + end + + it 'returns data for all the resources' do + expect(json['data'].length).to eq(resource_count) + end + end + end + + context 'with a single resource' do + describe '#GET the resource by ID' do + let(:resource) { create(:bait_library_layout) } + + context 'without included relationships' do + before { api_get "#{base_endpoint}/#{resource.id}" } + + it 'responds with a success http code' do + expect(response).to have_http_status(:success) + end + + it 'returns the correct resource' do + expect(json.dig('data', 'id')).to eq(resource.id.to_s) + expect(json.dig('data', 'type')).to eq(resource_type) + end + + it 'returns the correct attributes' do + expect(json.dig('data', 'attributes', 'layout')).to eq(resource.layout) + expect(json.dig('data', 'attributes', 'uuid')).to eq(resource.uuid) + end + + it 'excludes unfetchable attributes' do + expect(json.dig('data', 'attributes', 'plate_uuid')).not_to be_present + expect(json.dig('data', 'attributes', 'user_uuid')).not_to be_present + end + + it 'returns references to related resources' do + expect(json.dig('data', 'relationships', 'plate')).to be_present + expect(json.dig('data', 'relationships', 'user')).to be_present + end + + it 'does not include attributes for related resources' do + expect(json['included']).not_to be_present + end + end + + context 'with included relationships' do + context 'with plate' do + let(:related_name) { 'plate' } + + it_behaves_like 'a POST request including a has_one relationship' + end + + context 'with user' do + let(:related_name) { 'user' } + + it_behaves_like 'a POST request including a has_one relationship' + end + end + end + end + + describe '#PATCH a resource' do + let(:resource) { create(:bait_library_layout) } + let(:payload) do + { + 'data' => { + 'id' => resource.id, + 'type' => resource_type, + 'attributes' => { + 'user_uuid' => '11111111-2222-3333-4444-555555666666' + } + } + } + end + + it 'finds no route for the method' do + expect { api_patch "#{base_endpoint}/#{resource.id}", payload }.to raise_error(ActionController::RoutingError) + end + end + + describe '#POST' do + let(:user) { create(:user) } + let(:plate) { create(:plate) } + + describe 'a create request' do + let(:base_attributes) { {} } # There are no attributes to set besides ones for relationships being tested. + + let(:user_relationship) { { 'data' => { 'id' => user.id, 'type' => 'users' } } } + let(:plate_relationship) { { 'data' => { 'id' => plate.id, 'type' => 'plates' } } } + + context 'with a valid payload' do + shared_examples 'a valid POST request' do + def perform_post + api_post base_endpoint, payload + end + + it 'creates a new resource' do + expect { perform_post }.to change(model_class, :count).by(1) + end + + it 'responds with success' do + perform_post + + expect(response).to have_http_status(:success) + end + + it 'responds with the correct attributes' do + perform_post + new_record = model_class.last + + expect(json.dig('data', 'type')).to eq(resource_type) + expect(json.dig('data', 'attributes', 'layout')).to eq(new_record.layout) + end + + it 'excludes unfetchable attributes' do + perform_post + + expect(json.dig('data', 'attributes', 'plate_uuid')).not_to be_present + expect(json.dig('data', 'attributes', 'user_uuid')).not_to be_present + end + + it 'returns references to related resources' do + perform_post + + expect(json.dig('data', 'relationships', 'plate')).to be_present + expect(json.dig('data', 'relationships', 'user')).to be_present + end + + it 'applies the relationships to the new record' do + perform_post + new_record = model_class.last + + expect(new_record.plate).to eq(plate) + expect(new_record.user).to eq(user) + end + end + + context 'with complete attributes' do + let(:payload) do + { + 'data' => { + 'type' => resource_type, + 'attributes' => base_attributes.merge({ 'user_uuid' => user.uuid, 'plate_uuid' => plate.uuid }) + } + } + end + + it_behaves_like 'a valid POST request' + end + + context 'with relationships' do + let(:payload) do + { + 'data' => { + 'type' => resource_type, + 'attributes' => base_attributes, + 'relationships' => { + 'user' => user_relationship, + 'plate' => plate_relationship + } + } + } + end + + it_behaves_like 'a valid POST request' + end + + context 'with conflicting relationships' do + let(:other_user) { create(:user) } + let(:other_plate) { create(:plate) } + let(:payload) do + { + 'data' => { + 'type' => resource_type, + 'attributes' => + base_attributes.merge({ 'user_uuid' => other_user.uuid, 'plate_uuid' => other_plate.uuid }), + 'relationships' => { + 'user' => user_relationship, + 'plate' => plate_relationship + } + } + } + end + + # This test should pass because the relationships are preferred over the attributes. + it_behaves_like 'a valid POST request' + end + end + + context 'with a read-only attribute in the payload' do + context 'with uuid' do + let(:disallowed_attribute) { 'uuid' } + let(:payload) do + { + 'data' => { + 'type' => resource_type, + 'attributes' => base_attributes.merge({ 'uuid' => '111111-2222-3333-4444-555555666666' }) + } + } + end + + it_behaves_like 'a POST request with a disallowed attribute' + end + end + + context 'without a required relationship' do + context 'without user_uuid' do + let(:error_detail_message) { "user - can't be blank" } + let(:payload) do + { + 'data' => { + 'type' => resource_type, + 'attributes' => base_attributes.merge({ 'plate_uuid' => plate.uuid }) + } + } + end + + it_behaves_like 'an unprocessable POST request with a specific error' + end + + context 'without plate_uuid' do + let(:error_detail_message) { "plate - can't be blank" } + let(:payload) do + { + 'data' => { + 'type' => resource_type, + 'attributes' => base_attributes.merge({ 'user_uuid' => user.uuid }) + } + } + end + + it_behaves_like 'an unprocessable POST request with a specific error' + end + + context 'without user' do + let(:error_detail_message) { "user - can't be blank" } + let(:payload) do + { + 'data' => { + 'type' => resource_type, + 'attributes' => base_attributes, + 'relationships' => { + 'plate' => plate_relationship + } + } + } + end + + it_behaves_like 'an unprocessable POST request with a specific error' + end + + context 'without plate' do + let(:error_detail_message) { "plate - can't be blank" } + let(:payload) do + { + 'data' => { + 'type' => resource_type, + 'attributes' => base_attributes, + 'relationships' => { + 'user' => user_relationship + } + } + } + end + + it_behaves_like 'an unprocessable POST request with a specific error' + end + end + end + + describe 'a preview request' do + let(:base_endpoint) { "/api/v2/#{resource_type}/preview" } + + let(:valid_payload) { { user_uuid: user.uuid, plate_uuid: plate.uuid } } + + context 'with a valid payload' do + before { api_post base_endpoint, valid_payload } + + it 'responds with success' do + expect(response).to have_http_status(:success) + end + + it 'returns the correct data parameters' do + expect(json.dig('data', 'id')).not_to be_present + expect(json.dig('data', 'type')).to eq(resource_type) + end + + it 'returns a layout as an attribute' do + expect(json.dig('data', 'attributes', 'layout')).not_to be_nil + end + end + + context 'without a required parameter' do + shared_examples 'a request with a missing parameter' do + let(:payload) { valid_payload.except(missing_parameter) } + + before { api_post base_endpoint, payload } + + it 'responds with bad_request' do + expect(response).to have_http_status(:bad_request) + end + + it 'returns an error message' do + expect(json).to eq( + 'errors' => [ + { + 'title' => 'Missing parameter', + 'detail' => "param is missing or the value is empty: #{missing_parameter}", + 'code' => 400, + 'status' => 400 + } + ] + ) + end + end + + context 'without plate_uuid' do + let(:missing_parameter) { :plate_uuid } + + it_behaves_like 'a request with a missing parameter' + end + + context 'without user_uuid' do + let(:missing_parameter) { :user_uuid } + + it_behaves_like 'a request with a missing parameter' + end + end + + context 'with a parameter for a missing record' do + shared_examples 'a request with a missing record' do + let(:payload) { valid_payload.merge(invalid_parameter => 'missing_uuid') } + + before { api_post base_endpoint, payload } + + it 'responds with bad_request' do + expect(response).to have_http_status(:bad_request) + end + + it 'returns an error message' do + expect(json).to eq( + 'errors' => [ + { + 'title' => 'Record not found', + 'detail' => "The #{resource_name} record identified by UUID 'missing_uuid' cannot be found", + 'code' => 400, + 'status' => 400 + } + ] + ) + end + end + + context 'with a missing plate' do + let(:invalid_parameter) { :plate_uuid } + let(:resource_name) { 'Plate' } + + it_behaves_like 'a request with a missing record' + end + + context 'with a missing user' do + let(:invalid_parameter) { :user_uuid } + let(:resource_name) { 'User' } + + it_behaves_like 'a request with a missing record' + end + end + + context 'with a resource validation error' do + let(:raised_exception) do + record = BaitLibraryLayout.new + record.errors.add(:base, 'error 1') + record.errors.add(:base, 'error 2') + + ActiveRecord::RecordInvalid.new(record) + end + + before do + allow(BaitLibraryLayout).to receive(:preview!).and_raise(raised_exception) + api_post base_endpoint, valid_payload + end + + it 'responds with unprocessable_entity' do + expect(response).to have_http_status(:unprocessable_entity) + end + + it 'returns all errors' do + expect(json).to eq( + 'errors' => [ + { 'title' => 'Validation failed', 'detail' => 'error 1', 'code' => 422, 'status' => 422 }, + { 'title' => 'Validation failed', 'detail' => 'error 2', 'code' => 422, 'status' => 422 } + ] + ) + end + end + end + end +end diff --git a/spec/requests/api/v2/comments_spec.rb b/spec/requests/api/v2/comments_spec.rb index 0689fc6fb6..26599cfa5f 100644 --- a/spec/requests/api/v2/comments_spec.rb +++ b/spec/requests/api/v2/comments_spec.rb @@ -25,7 +25,7 @@ end context 'with a Comment' do - let(:resource_model) { create :comment } + let(:resource_model) { create(:comment) } let(:payload) do { @@ -56,8 +56,8 @@ end describe '#post' do - let(:plate) { create :plate } - let!(:request) { create :well_request, asset: plate.wells.first } + let(:plate) { create(:plate) } + let!(:request) { create(:well_request, asset: plate.wells.first) } let(:payload) do { diff --git a/spec/requests/api/v2/custom_metadatum_collections_spec.rb b/spec/requests/api/v2/custom_metadatum_collections_spec.rb index 0c5f1c5571..47e254d67f 100644 --- a/spec/requests/api/v2/custom_metadatum_collections_spec.rb +++ b/spec/requests/api/v2/custom_metadatum_collections_spec.rb @@ -20,9 +20,9 @@ end context 'with a collection' do - let(:resource_model) { create :custom_metadatum_collection_with_metadata } - let(:user) { create :user } - let(:asset) { create :asset } + let(:resource_model) { create(:custom_metadatum_collection_with_metadata) } + let(:user) { create(:user) } + let(:asset) { create(:asset) } describe '#get' do it 'responds with success' do diff --git a/spec/requests/api/v2/labware_spec.rb b/spec/requests/api/v2/labware_spec.rb index fc45d9c744..f648eebba7 100644 --- a/spec/requests/api/v2/labware_spec.rb +++ b/spec/requests/api/v2/labware_spec.rb @@ -34,7 +34,7 @@ end context 'with a request' do - let(:resource_model) { create :sample_tube } + let(:resource_model) { create(:sample_tube) } it 'sends an individual labware' do api_get "#{base_endpoint}/#{resource_model.id}" @@ -44,7 +44,7 @@ end context 'with include' do - let(:custom_metadatum_collection) { create :custom_metadatum_collection_with_metadata } + let(:custom_metadatum_collection) { create(:custom_metadatum_collection_with_metadata) } let(:labware) { custom_metadatum_collection.asset } it 'sends an individual labware' do diff --git a/spec/requests/api/v2/lanes_spec.rb b/spec/requests/api/v2/lanes_spec.rb index d95271a712..b245adebf7 100644 --- a/spec/requests/api/v2/lanes_spec.rb +++ b/spec/requests/api/v2/lanes_spec.rb @@ -25,7 +25,7 @@ end context 'with a lane' do - let(:resource_model) { create :lane } + let(:resource_model) { create(:lane) } it 'sends an individual lane' do api_get "#{base_endpoint}/#{resource_model.id}" diff --git a/spec/requests/api/v2/lot_types_spec.rb b/spec/requests/api/v2/lot_types_spec.rb index dbec287485..b9443d4623 100644 --- a/spec/requests/api/v2/lot_types_spec.rb +++ b/spec/requests/api/v2/lot_types_spec.rb @@ -25,7 +25,7 @@ end context 'with a LotType' do - let(:resource_model) { create :lot_type } + let(:resource_model) { create(:lot_type) } let(:payload) do { diff --git a/spec/requests/api/v2/lots_spec.rb b/spec/requests/api/v2/lots_spec.rb index 28e8ab91bf..333d386dcb 100644 --- a/spec/requests/api/v2/lots_spec.rb +++ b/spec/requests/api/v2/lots_spec.rb @@ -25,7 +25,7 @@ end context 'with a Lot' do - let(:resource_model) { create :lot } + let(:resource_model) { create(:lot) } let(:payload) do { diff --git a/spec/requests/api/v2/orders_spec.rb b/spec/requests/api/v2/orders_spec.rb index cee4ec8334..0faeec1378 100644 --- a/spec/requests/api/v2/orders_spec.rb +++ b/spec/requests/api/v2/orders_spec.rb @@ -25,7 +25,7 @@ end context 'with a order' do - let(:resource_model) { create :order } + let(:resource_model) { create(:order) } let(:payload) do { diff --git a/spec/requests/api/v2/pick_lists_spec.rb b/spec/requests/api/v2/pick_lists_spec.rb index d4558a4a29..70683ef952 100644 --- a/spec/requests/api/v2/pick_lists_spec.rb +++ b/spec/requests/api/v2/pick_lists_spec.rb @@ -25,7 +25,7 @@ end context 'with a PickList' do - let(:resource_model) { create :pick_list } + let(:resource_model) { create(:pick_list) } let(:payload) do { 'data' => { @@ -56,12 +56,12 @@ describe 'POST' do before do - rt = create :cherrypick_request_type, key: 'cherrypick' - create :cherrypick_pipeline, request_type: rt + rt = create(:cherrypick_request_type, key: 'cherrypick') + create(:cherrypick_pipeline, request_type: rt) end context 'with pick_attributes' do - let(:wells) { create_list :untagged_well, 2 } + let(:wells) { create_list(:untagged_well, 2) } let(:payload) do { @@ -85,8 +85,8 @@ end context 'with labware_pick_attributes' do - let(:plate_1) { create :plate_with_untagged_wells, well_count: 1 } - let(:plate_2) { create :plate_with_untagged_wells, well_count: 2 } + let(:plate_1) { create(:plate_with_untagged_wells, well_count: 1) } + let(:plate_2) { create(:plate_with_untagged_wells, well_count: 2) } let(:payload) do { diff --git a/spec/requests/api/v2/plate_purposes_spec.rb b/spec/requests/api/v2/plate_purposes_spec.rb index 48764c0ae0..2522656370 100644 --- a/spec/requests/api/v2/plate_purposes_spec.rb +++ b/spec/requests/api/v2/plate_purposes_spec.rb @@ -51,7 +51,7 @@ end describe '#post' do - let(:asset_shape) { create :asset_shape } + let(:asset_shape) { create(:asset_shape) } context 'with valid payload' do def payload(bools) diff --git a/spec/requests/api/v2/plate_templates_spec.rb b/spec/requests/api/v2/plate_templates_spec.rb index 88149841a9..9b259151de 100644 --- a/spec/requests/api/v2/plate_templates_spec.rb +++ b/spec/requests/api/v2/plate_templates_spec.rb @@ -25,7 +25,7 @@ end context 'with a PlateTemplate' do - let(:resource_model) { create :plate_template } + let(:resource_model) { create(:plate_template) } let(:payload) do { diff --git a/spec/requests/api/v2/plates_spec.rb b/spec/requests/api/v2/plates_spec.rb index 033b06ea04..d73a9414d8 100644 --- a/spec/requests/api/v2/plates_spec.rb +++ b/spec/requests/api/v2/plates_spec.rb @@ -33,9 +33,9 @@ end context 'when providing a payload using default JSON API' do - let(:purpose) { create :plate_purpose } - let(:well) { create :well } - let(:well2) { create :well } + let(:purpose) { create(:plate_purpose) } + let(:well) { create(:well) } + let(:well2) { create(:well) } let(:payload) do { 'data' => { @@ -82,8 +82,8 @@ end context 'with a plate' do - let(:resource_model) { create :plate } - let!(:resource_model_2) { create :plate } + let(:resource_model) { create(:plate) } + let!(:resource_model_2) { create(:plate) } it 'sends an individual plate' do api_get "#{base_endpoint}/#{resource_model.id}" @@ -99,7 +99,7 @@ context 'when the ancestor is a tube rack' do let(:purpose) { create(:plate_purpose, target_type: 'Plate', name: 'Stock Plate', size: '96') } - let(:rack) { create :tube_rack } + let(:rack) { create(:tube_rack) } let(:plate_factory) { Heron::Factories::PlateFromRack.new(tube_rack: rack, plate_purpose: purpose) } let(:tubes) { create_list(:sample_tube, 2) } diff --git a/spec/requests/api/v2/poly_metadata_spec.rb b/spec/requests/api/v2/poly_metadata_spec.rb index 606cb55c22..b3029adce5 100644 --- a/spec/requests/api/v2/poly_metadata_spec.rb +++ b/spec/requests/api/v2/poly_metadata_spec.rb @@ -25,7 +25,7 @@ end context 'with a PolyMetadatum' do - let(:resource_model) { create :poly_metadatum } + let(:resource_model) { create(:poly_metadatum) } let(:payload) do { @@ -61,8 +61,8 @@ end describe '#post' do - let(:plate) { create :plate } - let!(:request) { create :well_request, asset: plate.wells.first } + let(:plate) { create(:plate) } + let!(:request) { create(:well_request, asset: plate.wells.first) } let(:payload) do { diff --git a/spec/requests/api/v2/pooled_plate_creations_spec.rb b/spec/requests/api/v2/pooled_plate_creations_spec.rb new file mode 100644 index 0000000000..8436b20c0f --- /dev/null +++ b/spec/requests/api/v2/pooled_plate_creations_spec.rb @@ -0,0 +1,278 @@ +# frozen_string_literal: true + +require 'rails_helper' +require './spec/requests/api/v2/shared_examples/api_key_authenticatable' +require './spec/requests/api/v2/shared_examples/post_requests' + +describe 'Pooled Plate Creations API', with: :api_v2 do + let(:model_class) { PooledPlateCreation } + let(:base_endpoint) { "/api/v2/#{resource_type}" } + let(:resource_type) { model_class.name.demodulize.pluralize.underscore } + + it_behaves_like 'ApiKeyAuthenticatable' + + context 'with a list of resources' do + let(:resource_count) { 5 } + + before { create_list(:pooled_plate_creation, resource_count) } + + describe '#GET all resources' do + before { api_get base_endpoint } + + it 'responds with a success http code' do + expect(response).to have_http_status(:success) + end + + it 'returns all the resources' do + expect(json['data'].length).to eq(resource_count) + end + end + end + + context 'with a single resource' do + describe '#GET resource by ID' do + let(:resource) { create(:pooled_plate_creation) } + + context 'without included relationships' do + before { api_get "#{base_endpoint}/#{resource.id}" } + + it 'responds with a success http code' do + expect(response).to have_http_status(:success) + end + + it 'returns the correct resource' do + expect(json.dig('data', 'id')).to eq(resource.id.to_s) + expect(json.dig('data', 'type')).to eq(resource_type) + end + + it 'returns the correct attributes' do + expect(json.dig('data', 'attributes', 'uuid')).to eq(resource.uuid) + end + + it 'excludes unfetchable attributes' do + expect(json.dig('data', 'attributes', 'child_purpose_uuid')).not_to be_present + expect(json.dig('data', 'attributes', 'parent_uuids')).not_to be_present + expect(json.dig('data', 'attributes', 'tube_attributes')).not_to be_present + end + + it 'returns references to related resources' do + expect(json.dig('data', 'relationships', 'child')).to be_present + expect(json.dig('data', 'relationships', 'parents')).to be_present + expect(json.dig('data', 'relationships', 'user')).to be_present + end + + it 'does not include attributes for related resources' do + expect(json['included']).not_to be_present + end + end + + context 'with included relationships' do + context 'with child' do + let(:related_name) { 'child' } + + it_behaves_like 'a POST request including a has_one relationship' + end + + context 'with parents' do + let(:related_name) { 'parents' } + + it_behaves_like 'a POST request including a has_many relationship' + end + + context 'with user' do + let(:related_name) { 'user' } + + it_behaves_like 'a POST request including a has_one relationship' + end + end + end + end + + describe '#PATCH a resource' do + let(:resource_model) { create(:pooled_plate_creation) } + let(:purpose) { create(:plate_purpose) } + let(:payload) do + { data: { id: resource_model.id, type: resource_type, attributes: { child_purpose_uuid: [purpose.uuid] } } } + end + + it 'finds no route for the method' do + expect { api_patch "#{base_endpoint}/#{resource_model.id}", payload }.to raise_error( + ActionController::RoutingError + ) + end + end + + describe '#POST a create request' do + let(:purpose) { create(:plate_purpose) } + let(:parents) { [create(:plate), create(:tube, prefix: 'PT')] } + let(:user) { create(:user) } + + let(:base_attributes) { { child_purpose_uuid: purpose.uuid } } + + let(:parents_relationship) { { data: parents.map { |p| { id: p.id, type: 'labware' } } } } + let(:user_relationship) { { data: { id: user.id, type: 'users' } } } + + # Mock the plate barcode service because it is not available in the test environment. + # This wasn't needed above because the only records being created were via the factory which supplies a barcode. + include BarcodeHelper + before { mock_plate_barcode_service } + + context 'with a valid payload' do + shared_examples 'a valid request' do + before { api_post base_endpoint, payload } + + it 'creates a new resource' do + expect { api_post base_endpoint, payload }.to change(model_class, :count).by(1) + end + + it 'responds with success' do + expect(response).to have_http_status(:success) + end + + it 'responds with the correct attributes' do + new_record = model_class.last + + expect(json.dig('data', 'type')).to eq(resource_type) + expect(json.dig('data', 'attributes', 'uuid')).to eq(new_record.uuid) + end + + it 'excludes unfetchable attributes' do + expect(json.dig('data', 'attributes', 'child_purpose_uuid')).not_to be_present + expect(json.dig('data', 'attributes', 'parent_uuids')).not_to be_present + expect(json.dig('data', 'attributes', 'tube_attributes')).not_to be_present + end + + it 'returns references to related resources' do + expect(json.dig('data', 'relationships', 'child')).to be_present + expect(json.dig('data', 'relationships', 'parents')).to be_present + expect(json.dig('data', 'relationships', 'user')).to be_present + end + + it 'applies the relationships to the new record' do + new_record = model_class.last + + expect(new_record.child_purpose).to eq(purpose) + expect(new_record.parents).to eq(parents) + expect(new_record.user).to eq(user) + end + + it 'generated a child with valid attributes' do + new_record = model_class.last + + expect(new_record.child.purpose).to eq(purpose) + end + end + + context 'with complete attributes' do + let(:payload) do + { + data: { + type: resource_type, + attributes: base_attributes.merge({ parent_uuids: parents.map(&:uuid), user_uuid: user.uuid }) + } + } + end + + it_behaves_like 'a valid request' + end + + context 'with relationships' do + let(:payload) do + { + data: { + type: resource_type, + attributes: base_attributes, + relationships: { + parents: parents_relationship, + user: user_relationship + } + } + } + end + + it_behaves_like 'a valid request' + end + + context 'with conflicting relationships' do + let(:other_parents) { create_list(:plate, 2) } + let(:other_user) { create(:user) } + let(:payload) do + { + data: { + type: resource_type, + attributes: + base_attributes.merge({ parent_uuids: other_parents.map(&:uuid), user_uuid: other_user.uuid }), + relationships: { + parents: parents_relationship, + user: user_relationship + } + } + } + end + + # This test should pass because the relationships are preferred over the attributes. + it_behaves_like 'a valid request' + end + end + + context 'with a read-only attribute in the payload' do + context 'with uuid' do + let(:disallowed_attribute) { 'uuid' } + let(:payload) do + { + data: { + type: resource_type, + attributes: base_attributes.merge({ uuid: '111111-2222-3333-4444-555555666666' }) + } + } + end + + it_behaves_like 'a POST request with a disallowed attribute' + end + end + + context 'without a required relationship' do + context 'without parent_uuids' do + let(:error_detail_message) { "parent - can't be blank" } + let(:payload) { { data: { type: resource_type, attributes: base_attributes.merge({ user_uuid: user.uuid }) } } } + + it_behaves_like 'an unprocessable POST request with a specific error' + end + + context 'without user_uuid' do + let(:error_detail_message) { "user - can't be blank" } + let(:payload) do + { data: { type: resource_type, attributes: base_attributes.merge({ parent_uuids: parents.map(&:uuid) }) } } + end + + it_behaves_like 'an unprocessable POST request with a specific error' + end + + context 'without parents' do + let(:error_detail_message) { "parent - can't be blank" } + let(:payload) do + { data: { type: resource_type, attributes: base_attributes, relationships: { user: user_relationship } } } + end + + it_behaves_like 'an unprocessable POST request with a specific error' + end + + context 'without user' do + let(:error_detail_message) { "user - can't be blank" } + let(:payload) do + { + data: { + type: resource_type, + attributes: base_attributes, + relationships: { + parents: parents_relationship + } + } + } + end + + it_behaves_like 'an unprocessable POST request with a specific error' + end + end + end +end diff --git a/spec/requests/api/v2/pre_capture_pools_spec.rb b/spec/requests/api/v2/pre_capture_pools_spec.rb index c6a0bb2d04..82b8f9b2c2 100644 --- a/spec/requests/api/v2/pre_capture_pools_spec.rb +++ b/spec/requests/api/v2/pre_capture_pools_spec.rb @@ -25,7 +25,7 @@ end context 'with a pre_capture_pool' do - let(:resource_model) { create :pre_capture_pool } + let(:resource_model) { create(:pre_capture_pool) } let(:payload) do { diff --git a/spec/requests/api/v2/primer_panels_spec.rb b/spec/requests/api/v2/primer_panels_spec.rb index db580178d9..1fee512fd0 100644 --- a/spec/requests/api/v2/primer_panels_spec.rb +++ b/spec/requests/api/v2/primer_panels_spec.rb @@ -25,7 +25,7 @@ end context 'with a primer_panel' do - let(:resource_model) { create :primer_panel } + let(:resource_model) { create(:primer_panel) } let(:payload) do { diff --git a/spec/requests/api/v2/purposes_spec.rb b/spec/requests/api/v2/purposes_spec.rb index 05bb1a2a1b..09f43df832 100644 --- a/spec/requests/api/v2/purposes_spec.rb +++ b/spec/requests/api/v2/purposes_spec.rb @@ -36,7 +36,7 @@ end context 'with a purpose' do - let(:resource_model) { create :purpose } + let(:resource_model) { create(:purpose) } it 'sends an individual purpose' do api_get "#{base_endpoint}/#{resource_model.id}" diff --git a/spec/requests/api/v2/qcables_spec.rb b/spec/requests/api/v2/qcables_spec.rb index f146723760..03f2aff4c1 100644 --- a/spec/requests/api/v2/qcables_spec.rb +++ b/spec/requests/api/v2/qcables_spec.rb @@ -25,7 +25,7 @@ end context 'with a Qcable' do - let(:resource_model) { create :qcable } + let(:resource_model) { create(:qcable) } let(:payload) do { diff --git a/spec/requests/api/v2/receptacles_spec.rb b/spec/requests/api/v2/receptacles_spec.rb index e333bb0ea7..c13bb8432f 100644 --- a/spec/requests/api/v2/receptacles_spec.rb +++ b/spec/requests/api/v2/receptacles_spec.rb @@ -40,14 +40,7 @@ let(:coverage) { 100 } let(:diluent_volume) { 50.0 } - let(:receptacle) do - create :receptacle, - pcr_cycles: pcr_cycles, - submit_for_sequencing: submit_for_sequencing, - sub_pool: sub_pool, - coverage: coverage, - diluent_volume: diluent_volume - end + let(:receptacle) { create(:receptacle, pcr_cycles:, submit_for_sequencing:, sub_pool:, coverage:, diluent_volume:) } before { api_get "#{base_endpoint}/#{receptacle.id}" } diff --git a/spec/requests/api/v2/request_types_spec.rb b/spec/requests/api/v2/request_types_spec.rb index 72f1f8acfc..dde7b95cb8 100644 --- a/spec/requests/api/v2/request_types_spec.rb +++ b/spec/requests/api/v2/request_types_spec.rb @@ -25,7 +25,7 @@ end context 'with a request_type' do - let(:resource_model) { create :request_type } + let(:resource_model) { create(:request_type) } it 'sends an individual request_type' do api_get "#{base_endpoint}/#{resource_model.id}" diff --git a/spec/requests/api/v2/requests_spec.rb b/spec/requests/api/v2/requests_spec.rb index e55c11fdea..a733fa3de2 100644 --- a/spec/requests/api/v2/requests_spec.rb +++ b/spec/requests/api/v2/requests_spec.rb @@ -25,7 +25,7 @@ end context 'with a request' do - let(:resource_model) { create :request } + let(:resource_model) { create(:request) } it 'sends an individual request' do api_get "#{base_endpoint}/#{resource_model.id}?include=primer_panel" diff --git a/spec/requests/api/v2/sample_metadata_spec.rb b/spec/requests/api/v2/sample_metadata_spec.rb index 55251c6b5b..e511e72565 100644 --- a/spec/requests/api/v2/sample_metadata_spec.rb +++ b/spec/requests/api/v2/sample_metadata_spec.rb @@ -20,7 +20,7 @@ end context 'with a single metadata resource' do - let(:resource_model) { create :sample_metadata_for_api } + let(:resource_model) { create(:sample_metadata_for_api) } describe '#get' do it 'generates a success response' do diff --git a/spec/requests/api/v2/shared_examples/api_key_authenticatable.rb b/spec/requests/api/v2/shared_examples/api_key_authenticatable.rb index 0fae5d16b8..5b93545c22 100644 --- a/spec/requests/api/v2/shared_examples/api_key_authenticatable.rb +++ b/spec/requests/api/v2/shared_examples/api_key_authenticatable.rb @@ -30,7 +30,7 @@ let(:headers) { client_headers.merge!({ 'X-Sequencescape-Client-Id': 'invalid-key' }) } it 'gets an unauthorized response' do - api_get base_endpoint, headers: headers + api_get(base_endpoint, headers:) expect(response).to have_http_status(:unauthorized) end @@ -38,7 +38,7 @@ it 'logs the request with client details' do allow(Rails.logger).to receive(:info) - api_get base_endpoint, headers: headers + api_get(base_endpoint, headers:) expect(Rails.logger).to have_received(:info).with(/Request made with invalid API key/) expect(Rails.logger).to have_received(:info).with(/:remote_ip=>"127.0.0.1"/) @@ -55,7 +55,7 @@ let(:headers) { client_headers.merge!({ 'X-Sequencescape-Client-Id': api_application.key }) } it 'gets a success response' do - api_get base_endpoint, headers: headers + api_get(base_endpoint, headers:) expect(response).to have_http_status(:success) end diff --git a/spec/requests/api/v2/shared_examples/invalid_post_requests.rb b/spec/requests/api/v2/shared_examples/invalid_post_requests.rb deleted file mode 100644 index fa0308aa0f..0000000000 --- a/spec/requests/api/v2/shared_examples/invalid_post_requests.rb +++ /dev/null @@ -1,51 +0,0 @@ -# frozen_string_literal: true - -require 'rails_helper' - -shared_examples 'a POST request with a disallowed attribute' do - before { api_post base_endpoint, payload } - - it 'does not create a new resource' do - expect { api_post base_endpoint, payload }.not_to change(model_class, :count) - end - - it 'responds with bad_request' do - expect(response).to have_http_status(:bad_request) - end - - it 'specifies which attribute was not allowed' do - expect(json.dig('errors', 0, 'detail')).to eq("#{disallowed_attribute} is not allowed.") - end -end - -shared_examples 'a POST request with a missing attribute' do - before { api_post base_endpoint, payload } - - it 'does not create a new resource' do - expect { api_post base_endpoint, payload }.not_to change(model_class, :count) - end - - it 'responds with unprocessable_entity' do - expect(response).to have_http_status(:unprocessable_entity) - end - - it 'specifies which attribute cannot be blank' do - expect(json.dig('errors', 0, 'detail')).to eq("#{missing_attribute} - can't be blank") - end -end - -shared_examples 'a POST request without a required relationship' do - before { api_post base_endpoint, payload } - - it 'does not create a new resource' do - expect { api_post base_endpoint, payload }.not_to change(model_class, :count) - end - - it 'responds with unprocessable_entity' do - expect(response).to have_http_status(:unprocessable_entity) - end - - it 'specifies which relationship must exist' do - expect(json.dig('errors', 0, 'detail')).to eq("#{missing_relationship} - must exist") - end -end diff --git a/spec/requests/api/v2/shared_examples/post_requests.rb b/spec/requests/api/v2/shared_examples/post_requests.rb new file mode 100644 index 0000000000..84194a9a1c --- /dev/null +++ b/spec/requests/api/v2/shared_examples/post_requests.rb @@ -0,0 +1,63 @@ +# frozen_string_literal: true + +require 'rails_helper' + +shared_examples 'a POST request with a disallowed attribute' do + before { api_post base_endpoint, payload } + + it 'does not create a new resource' do + expect { api_post base_endpoint, payload }.not_to change(model_class, :count) + end + + it 'responds with bad_request' do + expect(response).to have_http_status(:bad_request) + end + + it 'specifies which attribute was not allowed' do + expect(json.dig('errors', 0, 'detail')).to eq("#{disallowed_attribute} is not allowed.") + end +end + +shared_examples 'an unprocessable POST request with a specific error' do + before { api_post base_endpoint, payload } + + it 'does not create a new resource' do + expect { api_post base_endpoint, payload }.not_to change(model_class, :count) + end + + it 'responds with unprocessable_entity' do + expect(response).to have_http_status(:unprocessable_entity) + end + + it 'specifies the expected error message' do + expect(json.dig('errors', 0, 'detail')).to eq(error_detail_message) + end +end + +shared_examples 'a POST request including a has_one relationship' do + before { api_get "#{base_endpoint}/#{resource.id}?include=#{related_name}" } + + it 'responds with a success http code' do + expect(response).to have_http_status(:success) + end + + it 'returns the expected relationship' do + related = json['data']['relationships'][related_name]['data'] + included = json['included'].map { |i| i.slice('id', 'type') } + expect(included).to include(related) + end +end + +shared_examples 'a POST request including a has_many relationship' do + before { api_get "#{base_endpoint}/#{resource.id}?include=#{related_name}" } + + it 'responds with a success http code' do + expect(response).to have_http_status(:success) + end + + it 'includes the expected relationships' do + related = json['data']['relationships'][related_name]['data'] + included = json['included'].map { |i| i.slice('id', 'type') } + expect(included).to include(*related) + end +end diff --git a/spec/requests/api/v2/specific_tube_creations_spec.rb b/spec/requests/api/v2/specific_tube_creations_spec.rb new file mode 100644 index 0000000000..160be165a1 --- /dev/null +++ b/spec/requests/api/v2/specific_tube_creations_spec.rb @@ -0,0 +1,292 @@ +# frozen_string_literal: true + +require 'rails_helper' +require './spec/requests/api/v2/shared_examples/api_key_authenticatable' +require './spec/requests/api/v2/shared_examples/post_requests' + +describe 'Specific Tube Creations API', with: :api_v2 do + let(:model_class) { SpecificTubeCreation } + let(:base_endpoint) { "/api/v2/#{resource_type}" } + let(:resource_type) { model_class.name.demodulize.pluralize.underscore } + + it_behaves_like 'ApiKeyAuthenticatable' + + context 'with a list of resources' do + let(:resource_count) { 5 } + + before { create_list(:specific_tube_creation, resource_count) } + + describe '#GET all resources' do + before { api_get base_endpoint } + + it 'responds with a success http code' do + expect(response).to have_http_status(:success) + end + + it 'returns all the resources' do + expect(json['data'].length).to eq(resource_count) + end + end + end + + context 'with a single resource' do + describe '#GET resource by ID' do + let(:resource) { create(:specific_tube_creation) } + + context 'without included relationships' do + before { api_get "#{base_endpoint}/#{resource.id}" } + + it 'responds with a success http code' do + expect(response).to have_http_status(:success) + end + + it 'returns the correct resource' do + expect(json.dig('data', 'id')).to eq(resource.id.to_s) + expect(json.dig('data', 'type')).to eq(resource_type) + end + + it 'returns the correct attributes' do + expect(json.dig('data', 'attributes', 'uuid')).to eq(resource.uuid) + end + + it 'excludes unfetchable attributes' do + expect(json.dig('data', 'attributes', 'child_purpose_uuids')).not_to be_present + expect(json.dig('data', 'attributes', 'parent_uuids')).not_to be_present + expect(json.dig('data', 'attributes', 'tube_attributes')).not_to be_present + end + + it 'returns references to related resources' do + expect(json.dig('data', 'relationships', 'children')).to be_present + expect(json.dig('data', 'relationships', 'parents')).to be_present + expect(json.dig('data', 'relationships', 'user')).to be_present + end + + it 'does not include attributes for related resources' do + expect(json['included']).not_to be_present + end + end + + context 'with included relationships' do + context 'with children' do + let(:related_name) { 'children' } + + it_behaves_like 'a POST request including a has_many relationship' + end + + context 'with parents' do + let(:related_name) { 'parents' } + + it_behaves_like 'a POST request including a has_many relationship' + end + + context 'with user' do + let(:related_name) { 'user' } + + it_behaves_like 'a POST request including a has_one relationship' + end + end + end + end + + describe '#PATCH a resource' do + let(:resource_model) { create(:specific_tube_creation) } + let(:purpose) { create(:tube_purpose) } + let(:payload) do + { data: { id: resource_model.id, type: resource_type, attributes: { child_purpose_uuids: [purpose.uuid] } } } + end + + it 'finds no route for the method' do + expect { api_patch "#{base_endpoint}/#{resource_model.id}", payload }.to raise_error( + ActionController::RoutingError + ) + end + end + + describe '#POST a create request' do + let(:child_purposes) { create_list(:tube_purpose, 2) } + let(:parents) { [create(:plate), create(:tube, prefix: 'PT')] } + let(:user) { create(:user) } + + let(:base_attributes) do + { child_purpose_uuids: child_purposes.map(&:uuid), tube_attributes: [{ name: 'Tube one' }, { name: 'Tube two' }] } + end + + let(:parents_relationship) { { data: parents.map { |p| { id: p.id, type: 'labware' } } } } + let(:user_relationship) { { data: { id: user.id, type: 'users' } } } + + context 'with a valid payload' do + shared_examples 'a valid request' do + before { api_post base_endpoint, payload } + + it 'creates a new resource' do + expect { api_post base_endpoint, payload }.to change(model_class, :count).by(1) + end + + it 'responds with success' do + expect(response).to have_http_status(:success) + end + + it 'responds with the correct attributes' do + new_record = model_class.last + + expect(json.dig('data', 'type')).to eq(resource_type) + expect(json.dig('data', 'attributes', 'uuid')).to eq(new_record.uuid) + end + + it 'excludes unfetchable attributes' do + expect(json.dig('data', 'attributes', 'child_purpose_uuids')).not_to be_present + expect(json.dig('data', 'attributes', 'parent_uuids')).not_to be_present + expect(json.dig('data', 'attributes', 'tube_attributes')).not_to be_present + end + + it 'returns references to related resources' do + expect(json.dig('data', 'relationships', 'children')).to be_present + expect(json.dig('data', 'relationships', 'parents')).to be_present + expect(json.dig('data', 'relationships', 'user')).to be_present + end + + it 'applies the attributes to the new record' do + new_record = model_class.last + + # Note that the tube_attributes from the queried record will not match the submitted values, but it will + # consist of empty hashes equalling the number of child purposes, as defined in the model. + expect(new_record.tube_attributes).to eq(Array.new(child_purposes.length, {})) + end + + it 'applies the relationships to the new record' do + new_record = model_class.last + + expect(new_record.child_purposes).to eq(child_purposes) + expect(new_record.parents).to eq(parents) + expect(new_record.user).to eq(user) + end + + it 'generated children with valid attributes' do + new_record = model_class.last + + expect(new_record.children.length).to eq(2) + expect(new_record.children.map(&:name)).to eq(['Tube one', 'Tube two']) + expect(new_record.children.map(&:purpose)).to eq(child_purposes) + end + end + + context 'with complete attributes' do + let(:payload) do + { + data: { + type: resource_type, + attributes: + base_attributes.merge( + { + child_purpose_uuids: child_purposes.map(&:uuid), + parent_uuids: parents.map(&:uuid), + user_uuid: user.uuid + } + ) + } + } + end + + it_behaves_like 'a valid request' + end + + context 'with relationships' do + let(:payload) do + { + data: { + type: resource_type, + attributes: base_attributes, + relationships: { + parents: parents_relationship, + user: user_relationship + } + } + } + end + + it_behaves_like 'a valid request' + end + + context 'with conflicting relationships' do + let(:other_parents) { create_list(:plate, 2) } + let(:other_user) { create(:user) } + let(:payload) do + { + data: { + type: resource_type, + attributes: + base_attributes.merge({ parent_uuids: other_parents.map(&:uuid), user_uuid: other_user.uuid }), + relationships: { + parents: parents_relationship, + user: user_relationship + } + } + } + end + + # This test should pass because the relationships are preferred over the attributes. + it_behaves_like 'a valid request' + end + end + + context 'with a read-only attribute in the payload' do + context 'with uuid' do + let(:disallowed_attribute) { 'uuid' } + let(:payload) do + { + data: { + type: resource_type, + attributes: base_attributes.merge({ uuid: '111111-2222-3333-4444-555555666666' }) + } + } + end + + it_behaves_like 'a POST request with a disallowed attribute' + end + end + + context 'without a required relationship' do + context 'without parent_uuids' do + let(:error_detail_message) { "parent - can't be blank" } + let(:payload) { { data: { type: resource_type, attributes: base_attributes.merge({ user_uuid: user.uuid }) } } } + + it_behaves_like 'an unprocessable POST request with a specific error' + end + + context 'without user_uuid' do + let(:error_detail_message) { "user - can't be blank" } + let(:payload) do + { data: { type: resource_type, attributes: base_attributes.merge({ parent_uuids: parents.map(&:uuid) }) } } + end + + it_behaves_like 'an unprocessable POST request with a specific error' + end + + context 'without parents' do + let(:error_detail_message) { "parent - can't be blank" } + let(:payload) do + { data: { type: resource_type, attributes: base_attributes, relationships: { user: user_relationship } } } + end + + it_behaves_like 'an unprocessable POST request with a specific error' + end + + context 'without user' do + let(:error_detail_message) { "user - can't be blank" } + let(:payload) do + { + data: { + type: resource_type, + attributes: base_attributes, + relationships: { + parents: parents_relationship + } + } + } + end + + it_behaves_like 'an unprocessable POST request with a specific error' + end + end + end +end diff --git a/spec/requests/api/v2/state_changes_spec.rb b/spec/requests/api/v2/state_changes_spec.rb index 585747c8cd..e0fee7fa14 100644 --- a/spec/requests/api/v2/state_changes_spec.rb +++ b/spec/requests/api/v2/state_changes_spec.rb @@ -2,50 +2,55 @@ require 'rails_helper' require './spec/requests/api/v2/shared_examples/api_key_authenticatable' -require './spec/requests/api/v2/shared_examples/invalid_post_requests' +require './spec/requests/api/v2/shared_examples/post_requests' describe 'State Changes API', with: :api_v2 do - let(:base_endpoint) { '/api/v2/state_changes' } let(:model_class) { StateChange } + let(:base_endpoint) { "/api/v2/#{resource_type}" } + let(:resource_type) { model_class.name.demodulize.pluralize.underscore } it_behaves_like 'ApiKeyAuthenticatable' - context 'with a list of StateChanges' do - let!(:state_changes) { create_list(:state_change, 5) } + context 'with a list of resource' do + let(:resource_count) { 5 } - describe '#GET all StateChanges' do + before { create_list(:state_change, resource_count) } + + describe '#GET all resources' do before { api_get base_endpoint } it 'responds with a success http code' do expect(response).to have_http_status(:success) end - it 'returns the full list of StateChanges' do - expect(json['data'].length).to eq(5) + it 'returns all the resources' do + expect(json['data'].length).to eq(resource_count) end end + end - describe '#GET StateChange by ID' do - let(:state_change) { state_changes.first } + context 'with a single resource' do + describe '#GET resource by ID' do + let(:resource) { create(:state_change) } context 'without included relationships' do - before { api_get "#{base_endpoint}/#{state_change.id}" } + before { api_get "#{base_endpoint}/#{resource.id}" } it 'responds with a success http code' do expect(response).to have_http_status(:success) end - it 'returns the correct StateChange' do - expect(json.dig('data', 'id')).to eq(state_change.id.to_s) - expect(json.dig('data', 'type')).to eq('state_changes') + it 'returns the correct resource' do + expect(json.dig('data', 'id')).to eq(resource.id.to_s) + expect(json.dig('data', 'type')).to eq(resource_type) end it 'returns the correct attributes' do - expect(json.dig('data', 'attributes', 'contents')).to eq(state_change.contents) - expect(json.dig('data', 'attributes', 'previous_state')).to eq(state_change.previous_state) - expect(json.dig('data', 'attributes', 'reason')).to eq(state_change.reason) - expect(json.dig('data', 'attributes', 'target_state')).to eq(state_change.target_state) - expect(json.dig('data', 'attributes', 'uuid')).to eq(state_change.uuid) + expect(json.dig('data', 'attributes', 'contents')).to eq(resource.contents) + expect(json.dig('data', 'attributes', 'previous_state')).to eq(resource.previous_state) + expect(json.dig('data', 'attributes', 'reason')).to eq(resource.reason) + expect(json.dig('data', 'attributes', 'target_state')).to eq(resource.target_state) + expect(json.dig('data', 'attributes', 'uuid')).to eq(resource.uuid) end it 'excludes unfetchable attributes' do @@ -55,8 +60,8 @@ end it 'returns references to related resources' do - expect(json.dig('data', 'relationships', 'user')).to be_present expect(json.dig('data', 'relationships', 'target')).to be_present + expect(json.dig('data', 'relationships', 'user')).to be_present end it 'does not include attributes for related resources' do @@ -65,34 +70,28 @@ end context 'with included relationships' do - before { api_get "#{base_endpoint}/#{state_change.id}?include=user,target" } + context 'with user' do + let(:related_name) { 'user' } - it 'responds with a success http code' do - expect(response).to have_http_status(:success) + it_behaves_like 'a POST request including a has_one relationship' end - it 'returns the correct user relationship' do - user = json['included'].find { |i| i['type'] == 'users' } - expect(user['id']).to eq(state_change.user.id.to_s) - expect(user['type']).to eq('users') - end + context 'with target' do + let(:related_name) { 'target' } - it 'returns the correct target relationship' do - target = json['included'].find { |i| i['type'] == 'labware' } - expect(target['id']).to eq(state_change.target.id.to_s) - expect(target['type']).to eq('labware') + it_behaves_like 'a POST request including a has_one relationship' end end end end - describe '#PATCH a StateChange' do + describe '#PATCH a resource' do let(:resource_model) { create(:state_change) } let(:payload) do { 'data' => { 'id' => resource_model.id, - 'type' => 'state_changes', + 'type' => resource_type, 'attributes' => { 'target_state' => 'passed' } @@ -107,7 +106,7 @@ end end - describe '#POST a new StateChange' do + describe '#POST a create request' do let(:user) { create(:user) } let(:plate) { create(:plate) } @@ -128,7 +127,7 @@ before { api_post base_endpoint, payload } it 'creates a new resource' do - expect { api_post base_endpoint, payload }.to change(StateChange, :count).by(1) + expect { api_post base_endpoint, payload }.to change(model_class, :count).by(1) end it 'responds with success' do @@ -136,12 +135,12 @@ end it 'responds with the correct attributes' do - expect(json.dig('data', 'type')).to eq('state_changes') - expect(json.dig('data', 'attributes', 'contents')).to eq(payload.dig('data', 'attributes', 'contents')) - expect(json.dig('data', 'attributes', 'reason')).to eq(payload.dig('data', 'attributes', 'reason')) - expect(json.dig('data', 'attributes', 'target_state')).to eq( - payload.dig('data', 'attributes', 'target_state') - ) + new_record = model_class.last + + expect(json.dig('data', 'type')).to eq(resource_type) + expect(json.dig('data', 'attributes', 'contents')).to eq(new_record.contents) + expect(json.dig('data', 'attributes', 'reason')).to eq(new_record.reason) + expect(json.dig('data', 'attributes', 'target_state')).to eq(new_record.target_state) end it 'excludes unfetchable attributes' do @@ -156,7 +155,7 @@ end it 'applies the attributes to the new record' do - new_record = StateChange.last + new_record = model_class.last expect(new_record.contents).to eq(payload.dig('data', 'attributes', 'contents')) expect(new_record.reason).to eq(payload.dig('data', 'attributes', 'reason')) @@ -164,7 +163,7 @@ end it 'applies the relationships to the new record' do - new_record = StateChange.last + new_record = model_class.last expect(new_record.user).to eq(user) expect(new_record.target).to eq(plate) @@ -175,7 +174,7 @@ let(:payload) do { 'data' => { - 'type' => 'state_changes', + 'type' => resource_type, 'attributes' => base_attributes.merge({ 'user_uuid' => user.uuid, 'target_uuid' => plate.uuid }) } } @@ -188,7 +187,7 @@ let(:payload) do { 'data' => { - 'type' => 'state_changes', + 'type' => resource_type, 'attributes' => base_attributes, 'relationships' => { 'user' => user_relationship, @@ -207,7 +206,7 @@ let(:payload) do { 'data' => { - 'type' => 'state_changes', + 'type' => resource_type, 'attributes' => base_attributes.merge({ 'user_uuid' => other_user.uuid, 'target_uuid' => other_plate.uuid }), 'relationships' => { @@ -229,7 +228,7 @@ let(:payload) do { 'data' => { - 'type' => 'state_changes', + 'type' => resource_type, 'attributes' => base_attributes.merge({ 'previous_state' => 'waiting' }) } } @@ -243,7 +242,7 @@ let(:payload) do { 'data' => { - 'type' => 'state_changes', + 'type' => resource_type, 'attributes' => base_attributes.merge({ 'uuid' => '111111-2222-3333-4444-555555666666' }) } } @@ -255,56 +254,51 @@ context 'without a required attribute' do context 'without target_state' do - let(:missing_attribute) { 'target_state' } + let(:error_detail_message) { "target_state - can't be blank" } let(:payload) do { 'data' => { - 'type' => 'state_changes', + 'type' => resource_type, 'attributes' => base_attributes.merge({ 'target_state' => nil, 'user_uuid' => user.uuid, 'target_uuid' => plate.uuid }) } } end - it_behaves_like 'a POST request with a missing attribute' + it_behaves_like 'an unprocessable POST request with a specific error' end end context 'without a required relationship' do context 'without user_uuid' do - let(:missing_relationship) { 'user' } + let(:error_detail_message) { 'user - must exist' } let(:payload) do { 'data' => { - 'type' => 'state_changes', + 'type' => resource_type, 'attributes' => base_attributes.merge({ 'target_uuid' => plate.uuid }) } } end - it_behaves_like 'a POST request without a required relationship' + it_behaves_like 'an unprocessable POST request with a specific error' end context 'without target_uuid' do - let(:missing_relationship) { 'target' } + let(:error_detail_message) { 'target - must exist' } let(:payload) do - { - 'data' => { - 'type' => 'state_changes', - 'attributes' => base_attributes.merge({ 'user_uuid' => user.uuid }) - } - } + { 'data' => { 'type' => resource_type, 'attributes' => base_attributes.merge({ 'user_uuid' => user.uuid }) } } end - it_behaves_like 'a POST request without a required relationship' + it_behaves_like 'an unprocessable POST request with a specific error' end context 'without user' do - let(:missing_relationship) { 'user' } + let(:error_detail_message) { 'user - must exist' } let(:payload) do { 'data' => { - 'type' => 'state_changes', + 'type' => resource_type, 'attributes' => base_attributes, 'relationships' => { 'target' => target_relationship @@ -313,15 +307,15 @@ } end - it_behaves_like 'a POST request without a required relationship' + it_behaves_like 'an unprocessable POST request with a specific error' end context 'without target' do - let(:missing_relationship) { 'target' } + let(:error_detail_message) { 'target - must exist' } let(:payload) do { 'data' => { - 'type' => 'state_changes', + 'type' => resource_type, 'attributes' => base_attributes, 'relationships' => { 'user' => user_relationship @@ -330,7 +324,7 @@ } end - it_behaves_like 'a POST request without a required relationship' + it_behaves_like 'an unprocessable POST request with a specific error' end end end diff --git a/spec/requests/api/v2/studies_spec.rb b/spec/requests/api/v2/studies_spec.rb index 57918382e6..b4badc72d6 100644 --- a/spec/requests/api/v2/studies_spec.rb +++ b/spec/requests/api/v2/studies_spec.rb @@ -36,7 +36,7 @@ end context 'with a study' do - let(:resource_model) { create :study } + let(:resource_model) { create(:study) } it 'sends an individual study' do api_get "#{base_endpoint}/#{resource_model.id}" diff --git a/spec/requests/api/v2/submissions_spec.rb b/spec/requests/api/v2/submissions_spec.rb index 3b3f0db2aa..3483f2004a 100644 --- a/spec/requests/api/v2/submissions_spec.rb +++ b/spec/requests/api/v2/submissions_spec.rb @@ -25,7 +25,7 @@ end context 'with a submission' do - let(:resource_model) { create :submission } + let(:resource_model) { create(:submission) } it 'sends an individual submission without tags' do api_get "#{base_endpoint}/#{resource_model.id}?fields[submissions]" diff --git a/spec/requests/api/v2/tag_groups_spec.rb b/spec/requests/api/v2/tag_groups_spec.rb index 25e1255d0c..a965576834 100644 --- a/spec/requests/api/v2/tag_groups_spec.rb +++ b/spec/requests/api/v2/tag_groups_spec.rb @@ -39,7 +39,7 @@ end context 'with a TagGroup' do - let(:resource_model) { create :tag_group } + let(:resource_model) { create(:tag_group) } let(:payload) do { diff --git a/spec/requests/api/v2/tag_layout_templates_spec.rb b/spec/requests/api/v2/tag_layout_templates_spec.rb index 90a47bb214..5adb31e515 100644 --- a/spec/requests/api/v2/tag_layout_templates_spec.rb +++ b/spec/requests/api/v2/tag_layout_templates_spec.rb @@ -46,7 +46,7 @@ end context 'with a TagLayoutTemplate' do - let(:resource_model) { create :tag_layout_template } + let(:resource_model) { create(:tag_layout_template) } describe '#get' do it 'responds with a success HTTP status code' do diff --git a/spec/requests/api/v2/tag_layouts_spec.rb b/spec/requests/api/v2/tag_layouts_spec.rb new file mode 100644 index 0000000000..f0da50b14a --- /dev/null +++ b/spec/requests/api/v2/tag_layouts_spec.rb @@ -0,0 +1,450 @@ +# frozen_string_literal: true + +require 'rails_helper' +require './spec/requests/api/v2/shared_examples/api_key_authenticatable' +require './spec/requests/api/v2/shared_examples/post_requests' + +describe 'Tag Layouts API', with: :api_v2 do + let(:model_class) { TagLayout } + let(:base_endpoint) { "/api/v2/#{resource_type}" } + let(:resource_type) { model_class.name.demodulize.pluralize.underscore } + + it_behaves_like 'ApiKeyAuthenticatable' + + context 'with a list of resources' do + let(:resource_count) { 5 } + + before { create_list(:tag_layout, resource_count) } + + describe '#GET all resources' do + before { api_get base_endpoint } + + it 'responds with a success http code' do + expect(response).to have_http_status(:success) + end + + it 'returns all the resources' do + expect(json['data'].length).to eq(resource_count) + end + end + end + + context 'with a single resource' do + describe '#GET resource by ID' do + let(:resource) { create(:tag_layout) } + + context 'without included relationships' do + before { api_get "#{base_endpoint}/#{resource.id}" } + + it 'responds with a success http code' do + expect(response).to have_http_status(:success) + end + + it 'returns the correct resource' do + expect(json.dig('data', 'id')).to eq(resource.id.to_s) + expect(json.dig('data', 'type')).to eq(resource_type) + end + + it 'returns the correct attributes' do + expect(json.dig('data', 'attributes', 'direction')).to eq(resource.direction) + expect(json.dig('data', 'attributes', 'initial_tag')).to eq(resource.initial_tag) + expect(json.dig('data', 'attributes', 'substitutions')).to eq(resource.substitutions) + expect(json.dig('data', 'attributes', 'tags_per_well')).to eq(resource.tags_per_well) + expect(json.dig('data', 'attributes', 'walking_by')).to eq(resource.walking_by) + expect(json.dig('data', 'attributes', 'uuid')).to eq(resource.uuid) + end + + it 'excludes unfetchable attributes' do + expect(json.dig('data', 'attributes', 'plate_uuid')).not_to be_present + expect(json.dig('data', 'attributes', 'tag_group_uuid')).not_to be_present + expect(json.dig('data', 'attributes', 'tag2_group_uuid')).not_to be_present + expect(json.dig('data', 'attributes', 'user_uuid')).not_to be_present + end + + it 'returns references to related resources' do + expect(json.dig('data', 'relationships', 'plate')).to be_present + expect(json.dig('data', 'relationships', 'tag_group')).to be_present + expect(json.dig('data', 'relationships', 'tag2_group')).to be_present + expect(json.dig('data', 'relationships', 'user')).to be_present + end + + it 'does not include attributes for related resources' do + expect(json['included']).not_to be_present + end + end + + context 'with included relationships' do + context 'with plate' do + let(:related_name) { 'plate' } + + it_behaves_like 'a POST request including a has_one relationship' + end + + context 'with user' do + let(:related_name) { 'user' } + + it_behaves_like 'a POST request including a has_one relationship' + end + end + end + end + + describe '#PATCH a resource' do + let(:resource_model) { create(:tag_layout) } + let(:payload) { { data: { id: resource_model.id, type: resource_type, attributes: { direction: 'columns' } } } } + + it 'finds no route for the method' do + expect { api_patch "#{base_endpoint}/#{resource_model.id}", payload }.to raise_error( + ActionController::RoutingError + ) + end + end + + describe '#POST a create request' do + let(:plate) { create(:plate) } + let(:tag_group) { create(:tag_group) } + let(:tag2_group) { create(:tag_group) } + let(:user) { create(:user) } + + let(:base_attributes) do + { + direction: 'column', + initial_tag: 0, + substitutions: { + 'A1' => 'B2' + }, + tags_per_well: 1, # Ignored by the walking_by algorithm below + walking_by: 'wells of plate' + } + end + + let(:plate_relationship) { { data: { id: plate.id, type: 'plates' } } } + let(:tag_group_relationship) { { data: { id: tag_group.id, type: 'tag_groups' } } } + let(:tag2_group_relationship) { { data: { id: tag2_group.id, type: 'tag_groups' } } } + let(:user_relationship) { { data: { id: user.id, type: 'users' } } } + + context 'with a valid payload' do + shared_examples 'a valid request' do + before { api_post base_endpoint, payload } + + it 'creates a new resource' do + expect { api_post base_endpoint, payload }.to change(model_class, :count).by(1) + end + + it 'responds with success' do + expect(response).to have_http_status(:success) + end + + it 'responds with the correct attributes' do + new_record = model_class.last + + expect(json.dig('data', 'type')).to eq(resource_type) + expect(json.dig('data', 'attributes', 'direction')).to eq(new_record.direction) + expect(json.dig('data', 'attributes', 'initial_tag')).to eq(new_record.initial_tag) + expect(json.dig('data', 'attributes', 'substitutions')).to eq(new_record.substitutions) + expect(json.dig('data', 'attributes', 'walking_by')).to eq(new_record.walking_by) + expect(json.dig('data', 'attributes', 'uuid')).to eq(new_record.uuid) + + # Note that the tags per well will not be saved with the record as it isn't a stored attribute in the + # database. The response is based on the model after being saved, which still holds the value given in the + # payload. + expect(json.dig('data', 'attributes', 'tags_per_well')).to eq(payload.dig(:data, :attributes, :tags_per_well)) + end + + it 'excludes unfetchable attributes' do + expect(json.dig('data', 'attributes', 'plate_uuid')).not_to be_present + expect(json.dig('data', 'attributes', 'tag_group_uuid')).not_to be_present + expect(json.dig('data', 'attributes', 'tag2_group_uuid')).not_to be_present + expect(json.dig('data', 'attributes', 'user_uuid')).not_to be_present + end + + it 'returns references to related resources' do + expect(json.dig('data', 'relationships', 'plate')).to be_present + expect(json.dig('data', 'relationships', 'tag_group')).to be_present + expect(json.dig('data', 'relationships', 'tag2_group')).to be_present + expect(json.dig('data', 'relationships', 'user')).to be_present + end + + it 'applies the attributes to the new record' do + new_record = model_class.last + + expect(new_record.direction).to eq(payload.dig(:data, :attributes, :direction)) + expect(new_record.initial_tag).to eq(payload.dig(:data, :attributes, :initial_tag)) + expect(new_record.substitutions).to eq(payload.dig(:data, :attributes, :substitutions)) + expect(new_record.walking_by).to eq(payload.dig(:data, :attributes, :walking_by)) + + # Note that the tags_per_well from the queried record will be nil as it isn't a stored attribute in the + # database. + expect(new_record.tags_per_well).to be_nil + end + + it 'applies the relationships to the new record' do + new_record = model_class.last + + expect(new_record.plate).to eq(plate) + expect(new_record.tag_group).to eq(tag_group) + expect(new_record.tag2_group).to eq(tag2_group) + expect(new_record.user).to eq(user) + end + end + + context 'with complete attributes' do + let(:payload) do + { + data: { + type: resource_type, + attributes: + base_attributes.merge( + { + plate_uuid: plate.uuid, + tag_group_uuid: tag_group.uuid, + tag2_group_uuid: tag2_group.uuid, + user_uuid: user.uuid + } + ) + } + } + end + + it_behaves_like 'a valid request' + end + + context 'with relationships' do + let(:payload) do + { + data: { + type: resource_type, + attributes: base_attributes, + relationships: { + plate: plate_relationship, + tag_group: tag_group_relationship, + tag2_group: tag2_group_relationship, + user: user_relationship + } + } + } + end + + it_behaves_like 'a valid request' + end + + context 'with conflicting relationships' do + let(:other_plate) { create(:plate) } + let(:other_tag_group) { create(:tag_group) } + let(:other_tag2_group) { create(:tag_group) } + let(:other_user) { create(:user) } + let(:payload) do + { + data: { + type: resource_type, + attributes: + base_attributes.merge( + { + plate_uuid: other_plate.uuid, + tag_group_uuid: other_tag_group.uuid, + tag2_group_uuid: other_tag2_group.uuid, + user_uuid: other_user.uuid + } + ), + relationships: { + plate: plate_relationship, + tag_group: tag_group_relationship, + tag2_group: tag2_group_relationship, + user: user_relationship + } + } + } + end + + # This test should pass because the relationships are preferred over the attributes. + it_behaves_like 'a valid request' + end + end + + context 'with a read-only attribute in the payload' do + context 'with uuid' do + let(:disallowed_attribute) { 'uuid' } + let(:payload) do + { + data: { + type: resource_type, + attributes: base_attributes.merge({ uuid: '111111-2222-3333-4444-555555666666' }) + } + } + end + + it_behaves_like 'a POST request with a disallowed attribute' + end + end + + context 'without a required attribute' do + context 'without direction' do + let(:error_detail_message) { 'direction - must define a valid algorithm' } + let(:payload) do + { + data: { + type: resource_type, + attributes: + base_attributes.merge( + { direction: nil, plate_uuid: plate.uuid, tag_group_uuid: tag_group.uuid, user_uuid: user.uuid } + ) + } + } + end + + it_behaves_like 'an unprocessable POST request with a specific error' + end + + context 'without walking_by' do + let(:error_detail_message) { 'walking_by - must define a valid algorithm' } + let(:payload) do + { + data: { + type: resource_type, + attributes: + base_attributes.merge( + { walking_by: nil, plate_uuid: plate.uuid, tag_group_uuid: tag_group.uuid, user_uuid: user.uuid } + ) + } + } + end + + it_behaves_like 'an unprocessable POST request with a specific error' + end + end + + context 'with an invalid attribute value' do + context 'with an invalid direction' do + let(:error_detail_message) { 'direction - must define a valid algorithm' } + let(:payload) do + { + data: { + type: resource_type, + attributes: + base_attributes.merge( + { direction: '1', plate_uuid: plate.uuid, tag_group_uuid: tag_group.uuid, user_uuid: user.uuid } + ) + } + } + end + + it_behaves_like 'an unprocessable POST request with a specific error' + end + + context 'with an invalid walking_by' do + let(:error_detail_message) { 'walking_by - must define a valid algorithm' } + let(:payload) do + { + data: { + type: resource_type, + attributes: + base_attributes.merge( + { walking_by: '1', plate_uuid: plate.uuid, tag_group_uuid: tag_group.uuid, user_uuid: user.uuid } + ) + } + } + end + + it_behaves_like 'an unprocessable POST request with a specific error' + end + end + + context 'without a required relationship' do + context 'without plate_uuid' do + let(:error_detail_message) { 'plate - must exist' } + let(:payload) do + { + data: { + type: resource_type, + attributes: base_attributes.merge({ tag_group_uuid: tag_group.uuid, user_uuid: user.uuid }) + } + } + end + + it_behaves_like 'an unprocessable POST request with a specific error' + end + + context 'without tag_group_uuid' do + let(:error_detail_message) { 'tag_group - must exist' } + let(:payload) do + { + data: { + type: resource_type, + attributes: base_attributes.merge({ plate_uuid: plate.uuid, user_uuid: user.uuid }) + } + } + end + + it_behaves_like 'an unprocessable POST request with a specific error' + end + + context 'without user_uuid' do + let(:error_detail_message) { 'user - must exist' } + let(:payload) do + { + data: { + type: resource_type, + attributes: base_attributes.merge({ plate_uuid: plate.uuid, tag_group_uuid: tag_group.uuid }) + } + } + end + + it_behaves_like 'an unprocessable POST request with a specific error' + end + + context 'without plate' do + let(:error_detail_message) { 'plate - must exist' } + let(:payload) do + { + data: { + type: resource_type, + attributes: base_attributes, + relationships: { + tag_group: tag_group_relationship, + user: user_relationship + } + } + } + end + + it_behaves_like 'an unprocessable POST request with a specific error' + end + + context 'without tag_group' do + let(:error_detail_message) { 'tag_group - must exist' } + let(:payload) do + { + data: { + type: resource_type, + attributes: base_attributes, + relationships: { + plate: plate_relationship, + user: user_relationship + } + } + } + end + + it_behaves_like 'an unprocessable POST request with a specific error' + end + + context 'without user' do + let(:error_detail_message) { 'user - must exist' } + let(:payload) do + { + data: { + type: resource_type, + attributes: base_attributes, + relationships: { + plate: plate_relationship, + tag_group: tag_group_relationship + } + } + } + end + + it_behaves_like 'an unprocessable POST request with a specific error' + end + end + end +end diff --git a/spec/requests/api/v2/transfer_requests_spec.rb b/spec/requests/api/v2/transfer_requests_spec.rb index 2459d2173b..9c87eed187 100644 --- a/spec/requests/api/v2/transfer_requests_spec.rb +++ b/spec/requests/api/v2/transfer_requests_spec.rb @@ -25,7 +25,7 @@ end context 'with a TransferRequest' do - let(:resource_model) { create :transfer_request_with_submission } + let(:resource_model) { create(:transfer_request_with_submission) } let(:payload) do { diff --git a/spec/requests/api/v2/transfers/transfers_spec.rb b/spec/requests/api/v2/transfers/transfers_spec.rb index 417a2206de..12a09bc13c 100644 --- a/spec/requests/api/v2/transfers/transfers_spec.rb +++ b/spec/requests/api/v2/transfers/transfers_spec.rb @@ -2,7 +2,7 @@ require 'rails_helper' require './spec/requests/api/v2/shared_examples/api_key_authenticatable' -require './spec/requests/api/v2/shared_examples/invalid_post_requests' +require './spec/requests/api/v2/shared_examples/post_requests' describe 'Transfer API', with: :api_v2 do let(:base_endpoint) { '/api/v2/transfers/transfers' } @@ -27,7 +27,7 @@ describe '#get Transfer by ID' do context 'with all relationships' do - let(:transfer) { create :transfer_between_plates } + let(:transfer) { create(:transfer_between_plates) } before { api_get "#{base_endpoint}/#{transfer.id}" } @@ -51,7 +51,7 @@ # Some old data may not have a User relationship even though it's required for new records. context 'without a User relationship' do - let(:transfer) { create :transfer_between_plates } + let(:transfer) { create(:transfer_between_plates) } before do # We need to remove the user relationship without invoking validations. @@ -165,23 +165,23 @@ context 'without user_uuid' do let(:attribute_to_remove) { 'user_uuid' } - let(:missing_attribute) { 'user' } + let(:error_detail_message) { "user - can't be blank" } - it_behaves_like 'a POST request with a missing attribute' + it_behaves_like 'an unprocessable POST request with a specific error' end context 'without source_uuid' do let(:attribute_to_remove) { 'source_uuid' } - let(:missing_attribute) { 'source' } + let(:error_detail_message) { "source - can't be blank" } - it_behaves_like 'a POST request with a missing attribute' + it_behaves_like 'an unprocessable POST request with a specific error' end context 'without destination_uuid' do let(:attribute_to_remove) { 'destination_uuid' } - let(:missing_attribute) { 'destination' } + let(:error_detail_message) { "destination - can't be blank" } - it_behaves_like 'a POST request with a missing attribute' + it_behaves_like 'an unprocessable POST request with a specific error' end end diff --git a/spec/requests/api/v2/tube_racks_spec.rb b/spec/requests/api/v2/tube_racks_spec.rb index e32735f2b4..2616a28a7e 100644 --- a/spec/requests/api/v2/tube_racks_spec.rb +++ b/spec/requests/api/v2/tube_racks_spec.rb @@ -25,7 +25,7 @@ end context 'with a TubeRack' do - let(:resource_model) { create :tube_rack } + let(:resource_model) { create(:tube_rack) } let(:payload) do { diff --git a/spec/requests/api/v2/tubes_spec.rb b/spec/requests/api/v2/tubes_spec.rb index 49082d317d..d5e8fd2c9e 100644 --- a/spec/requests/api/v2/tubes_spec.rb +++ b/spec/requests/api/v2/tubes_spec.rb @@ -30,7 +30,7 @@ end context 'with a tube' do - let(:resource_model) { create :tube } + let(:resource_model) { create(:tube) } it 'sends an individual tube' do api_get "#{base_endpoint}/#{resource_model.id}" diff --git a/spec/requests/api/v2/users_spec.rb b/spec/requests/api/v2/users_spec.rb index e87f01c2c5..5f44db92f4 100644 --- a/spec/requests/api/v2/users_spec.rb +++ b/spec/requests/api/v2/users_spec.rb @@ -28,7 +28,7 @@ let(:swipecard_code) { '1234567' } before do - user.update(swipecard_code: swipecard_code) + user.update(swipecard_code:) api_get "#{base_endpoint}?filter[user_code]=#{swipecard_code}" end @@ -76,7 +76,7 @@ end context 'with a User' do - let(:resource_model) { create :user } + let(:resource_model) { create(:user) } describe '#get' do before { api_get "#{base_endpoint}/#{resource_model.id}" } @@ -97,7 +97,7 @@ end describe '#patch' do - let(:resource_model) { create :user } + let(:resource_model) { create(:user) } let(:payload) { { 'data' => { 'id' => resource_model.id, 'type' => 'users', 'attributes' => {} } } } it 'cannot find a route to the endpoint' do diff --git a/spec/requests/api/v2/volume_update_spec.rb b/spec/requests/api/v2/volume_update_spec.rb index 82c1f31569..8767586e27 100644 --- a/spec/requests/api/v2/volume_update_spec.rb +++ b/spec/requests/api/v2/volume_update_spec.rb @@ -50,7 +50,7 @@ end describe '#post' do - let(:plate) { create :plate } # Only works for plates as update_volume is not set for all labware + let(:plate) { create(:plate) } # Only works for plates as update_volume is not set for all labware let(:payload) do { diff --git a/spec/requests/api/v2/wells_spec.rb b/spec/requests/api/v2/wells_spec.rb index 912695e16d..b2a717647e 100644 --- a/spec/requests/api/v2/wells_spec.rb +++ b/spec/requests/api/v2/wells_spec.rb @@ -31,14 +31,7 @@ let(:coverage) { 100 } let(:diluent_volume) { 50.0 } - let(:well) do - create :well, - pcr_cycles: pcr_cycles, - submit_for_sequencing: submit_for_sequencing, - sub_pool: sub_pool, - coverage: coverage, - diluent_volume: diluent_volume - end + let(:well) { create(:well, pcr_cycles:, submit_for_sequencing:, sub_pool:, coverage:, diluent_volume:) } describe '#get' do before { api_get "#{base_endpoint}/#{well.id}" } diff --git a/spec/requests/api/v2/work_orders_spec.rb b/spec/requests/api/v2/work_orders_spec.rb index 48d3dfb01b..b6a25d625e 100644 --- a/spec/requests/api/v2/work_orders_spec.rb +++ b/spec/requests/api/v2/work_orders_spec.rb @@ -9,10 +9,10 @@ it_behaves_like 'ApiKeyAuthenticatable' context 'with multiple requests' do - let(:our_request_type) { create :request_type } - let(:other_request_type) { create :request_type } - let(:our_work_order_type) { create :work_order_type, name: our_request_type.key } - let(:other_work_order_type) { create :work_order_type, name: other_request_type.key } + let(:our_request_type) { create(:request_type) } + let(:other_request_type) { create(:request_type) } + let(:our_work_order_type) { create(:work_order_type, name: our_request_type.key) } + let(:other_work_order_type) { create(:work_order_type, name: other_request_type.key) } before do [ @@ -69,13 +69,13 @@ end context 'with relationships' do - let(:study) { create :study } - let(:well) { create :untagged_well } + let(:study) { create(:study) } + let(:well) { create(:untagged_well) } let(:sample) { well.samples.first } before do - request = create :library_request, initial_study: study, asset: well, project: nil - create :work_order, requests: [request] + request = create(:library_request, initial_study: study, asset: well, project: nil) + create(:work_order, requests: [request]) end let(:expected_includes) do @@ -99,8 +99,8 @@ end context 'with a request' do - let(:requests) { create_list :library_request, 2 } - let(:work_order) { create :work_order, requests: requests } + let(:requests) { create_list(:library_request, 2) } + let(:work_order) { create(:work_order, requests:) } let(:payload) do { diff --git a/spec/requests/pick_lists_request_spec.rb b/spec/requests/pick_lists_request_spec.rb index 5ce01e03fa..5a82c1e3aa 100644 --- a/spec/requests/pick_lists_request_spec.rb +++ b/spec/requests/pick_lists_request_spec.rb @@ -2,12 +2,12 @@ require 'rails_helper' RSpec.describe 'PickLists' do - let(:user) { create :user, password: 'password' } + let(:user) { create(:user, password: 'password') } before { post '/login', params: { login: user.login, password: 'password' } } describe 'GET index' do - before { create_list :pick_list, 2 } + before { create_list(:pick_list, 2) } it 'returns a list of pick-lists', :aggregate_failures do get '/pick_lists' @@ -17,7 +17,7 @@ end describe 'GET show' do - let(:pick_list) { create :pick_list } + let(:pick_list) { create(:pick_list) } it 'returns a pick-list', :aggregate_failures do get "/pick_lists/#{pick_list.id}" diff --git a/spec/requests/plate_picks_request_spec.rb b/spec/requests/plate_picks_request_spec.rb index ebaa591159..b09ddd77bb 100644 --- a/spec/requests/plate_picks_request_spec.rb +++ b/spec/requests/plate_picks_request_spec.rb @@ -2,18 +2,20 @@ require 'rails_helper' RSpec.describe 'PlatePicks' do - let(:user) { create :user, password: 'password' } + let(:user) { create(:user, password: 'password') } let(:headers) { { 'ACCEPT' => 'application/json' } } - let(:plate) { create :plate, well_count: 1 } - let(:destination_plate) { create :plate, well_count: 1 } + let(:plate) { create(:plate, well_count: 1) } + let(:destination_plate) { create(:plate, well_count: 1) } let(:released_cherrypick_batch) do - build :cherrypick_batch, - state: 'released', - request_attributes: [{ asset: plate.wells[0], target_asset: destination_plate.wells.first, state: 'passed' }] + build( + :cherrypick_batch, + state: 'released', + request_attributes: [{ asset: plate.wells[0], target_asset: destination_plate.wells.first, state: 'passed' }] + ) end - let(:released_other_batch) { build :batch, state: 'released', request_attributes: [{ asset: plate.wells[0] }] } + let(:released_other_batch) { build(:batch, state: 'released', request_attributes: [{ asset: plate.wells[0] }]) } let(:pending_cherrypick_batch) do - build :cherrypick_batch, state: 'pending', request_attributes: [{ asset: plate.wells[0] }] + build(:cherrypick_batch, state: 'pending', request_attributes: [{ asset: plate.wells[0] }]) end # We exclude the pending batches here, as they don't have pick information. @@ -55,14 +57,14 @@ end it 'returns the plate', :aggregate_failures do - get "/plate_picks/plates/#{plate.machine_barcode}", headers: headers + get("/plate_picks/plates/#{plate.machine_barcode}", headers:) expect(response.media_type).to eq('application/json') expect(response).to have_http_status(:success) expect(response.parsed_body).to eq(found_plate) end it 'returns 404 if the plate is missing', :aggregate_failures do - get '/plate_picks/plates/not_a_barcode', headers: headers + get('/plate_picks/plates/not_a_barcode', headers:) expect(response.media_type).to eq('application/json') expect(response).to have_http_status(:not_found) expect(response.body).to eq(missing_plate) @@ -71,28 +73,28 @@ describe 'GET batches/:id' do before do - create :robot_with_verification_behaviour + create(:robot_with_verification_behaviour) released_cherrypick_batch.save! pending_cherrypick_batch.save! released_other_batch.save! end it 'returns the batch', :aggregate_failures do - get "/plate_picks/batches/#{released_cherrypick_batch.id}", headers: headers + get("/plate_picks/batches/#{released_cherrypick_batch.id}", headers:) expect(response.media_type).to eq('application/json') expect(response).to have_http_status(:success) expect(response.parsed_body).to eq(found_batch) end it 'returns an error if the batch has no pick info', :aggregate_failures do - get "/plate_picks/batches/#{pending_cherrypick_batch.id}", headers: headers + get("/plate_picks/batches/#{pending_cherrypick_batch.id}", headers:) expect(response.media_type).to eq('application/json') expect(response).to have_http_status(:conflict) expect(response.body).to eq(not_suitable) end it 'returns 404 if the batch is missing', :aggregate_failures do - get '/plate_picks/batches/not_a_barcode', headers: headers + get('/plate_picks/batches/not_a_barcode', headers:) expect(response.media_type).to eq('application/json') expect(response).to have_http_status(:not_found) expect(response.body).to eq(missing_batch) diff --git a/spec/requests/qc_files_spec.rb b/spec/requests/qc_files_spec.rb index 83d3f5714e..58d2c25dfb 100644 --- a/spec/requests/qc_files_spec.rb +++ b/spec/requests/qc_files_spec.rb @@ -2,10 +2,10 @@ require 'rails_helper' RSpec.describe 'QcFiles' do - let(:authorised_app) { create :api_application } + let(:authorised_app) { create(:api_application) } describe 'create qc file' do - let(:filename) { Rails.root.join('spec/data/parsers/cardinal_pbmc_count.csv').expand_path } + let(:filename) { Rails.root.join('spec/data/parsers/pbmc_count.csv').expand_path } let(:file) { File.open(filename) } let(:plate) { create(:plate_with_empty_wells, well_count: 96) } @@ -13,16 +13,16 @@ headers = { 'HTTP_ACCEPT' => 'application/json', 'CONTENT_TYPE' => 'sequencescape/qc_file', - 'HTTP_CONTENT_DISPOSITION' => 'form-data; filename="cardinal_pbmc_count.csv"', + 'HTTP_CONTENT_DISPOSITION' => 'form-data; filename="pbmc_count.csv"', 'HTTP_X_SEQUENCESCAPE_CLIENT_ID' => authorised_app.key, 'HTTP_COOKIE' => '' } - post "/api/1/#{plate.uuid}/qc_files", params: file.read, headers: headers + post("/api/1/#{plate.uuid}/qc_files", params: file.read, headers: headers) expect(response).to have_http_status(:success) - expect(QcResult.count).to eq(16) + expect(QcResult.count).to eq(24) end end end diff --git a/spec/requests/users_request_spec.rb b/spec/requests/users_request_spec.rb index ab6d66e631..e0bc0b53de 100644 --- a/spec/requests/users_request_spec.rb +++ b/spec/requests/users_request_spec.rb @@ -2,7 +2,7 @@ require 'rails_helper' RSpec.describe 'Users' do - let(:user) { create :user, password: 'password' } + let(:user) { create(:user, password: 'password') } before { post '/login', params: { login: user.login, password: 'password' } } diff --git a/spec/resources/api/v2/aliquot_resource_spec.rb b/spec/resources/api/v2/aliquot_resource_spec.rb index c8fee4c81a..f9fd7794b8 100644 --- a/spec/resources/api/v2/aliquot_resource_spec.rb +++ b/spec/resources/api/v2/aliquot_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::AliquotResource, type: :resource do subject { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :aliquot } + let(:resource_model) { build_stubbed(:aliquot) } # Test attributes it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording diff --git a/spec/resources/api/v2/bait_library_layout_resource_spec.rb b/spec/resources/api/v2/bait_library_layout_resource_spec.rb new file mode 100644 index 0000000000..28a8fc8d68 --- /dev/null +++ b/spec/resources/api/v2/bait_library_layout_resource_spec.rb @@ -0,0 +1,18 @@ +# frozen_string_literal: true + +require 'rails_helper' +require './app/resources/api/v2/bait_library_layout_resource' + +RSpec.describe Api::V2::BaitLibraryLayoutResource, type: :resource do + subject(:resource) { described_class.new(resource_model, {}) } + + let(:resource_model) { build_stubbed(:bait_library_layout) } + + # Attributes + it { is_expected.to have_readonly_attribute :uuid } + it { is_expected.to have_readonly_attribute :layout } + + # Relationships + it { is_expected.to have_one(:plate).with_class_name('Plate') } + it { is_expected.to have_one(:user).with_class_name('User') } +end diff --git a/spec/resources/api/v2/barcode_printer_resource_spec.rb b/spec/resources/api/v2/barcode_printer_resource_spec.rb index 8c445b38fc..1026e8ffa9 100644 --- a/spec/resources/api/v2/barcode_printer_resource_spec.rb +++ b/spec/resources/api/v2/barcode_printer_resource_spec.rb @@ -6,34 +6,12 @@ RSpec.describe Api::V2::BarcodePrinterResource, type: :resource do subject(:resource) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :barcode_printer } + let(:resource_model) { build_stubbed(:barcode_printer) } # Test attributes - it 'has the expected attributes', :aggregate_failures do - expect(resource).not_to have_attribute :id - expect(resource).to have_attribute :uuid - expect(resource).to have_attribute :name - expect(resource).to have_attribute :print_service - expect(resource).to have_attribute :barcode_type - end + it { is_expected.to have_readonly_attribute :uuid } + it { is_expected.to have_readonly_attribute :print_service } + it { is_expected.to have_readonly_attribute :barcode_type } - # Updatable fields - it 'allows updating of read-write fields', :aggregate_failures do - expect(resource).to have_updatable_field :name - end - - it 'disallows updating of read only fields', :aggregate_failures do - expect(resource).not_to have_updatable_field :uuid - expect(resource).not_to have_updatable_field :print_service - expect(resource).not_to have_updatable_field :barcode_type - end - - # Filters - # eg. it { is_expected.to filter(:order_type) } - - # Associations - # eg. it { is_expected.to have_many(:samples).with_class_name('Sample') } - - # Custom method tests - # Add tests for any custom methods you've added. + it { is_expected.to have_readwrite_attribute :name } end diff --git a/spec/resources/api/v2/comment_resource_spec.rb b/spec/resources/api/v2/comment_resource_spec.rb index 45ad0e4baa..d6dbc109ff 100644 --- a/spec/resources/api/v2/comment_resource_spec.rb +++ b/spec/resources/api/v2/comment_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::CommentResource, type: :resource do subject { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :comment } + let(:resource_model) { build_stubbed(:comment) } # Test attributes it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording diff --git a/spec/resources/api/v2/custom_metadatum_collection_resource_spec.rb b/spec/resources/api/v2/custom_metadatum_collection_resource_spec.rb index 63aec31f3f..41c02ad640 100644 --- a/spec/resources/api/v2/custom_metadatum_collection_resource_spec.rb +++ b/spec/resources/api/v2/custom_metadatum_collection_resource_spec.rb @@ -6,34 +6,12 @@ RSpec.describe Api::V2::CustomMetadatumCollectionResource, type: :resource do subject(:resource) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :custom_metadatum_collection } + let(:resource_model) { build_stubbed(:custom_metadatum_collection) } # Test attributes - it 'has the expected attributes', :aggregate_failures do - expect(resource).to have_attribute :uuid - expect(resource).to have_attribute :user_id - expect(resource).to have_attribute :asset_id - expect(resource).to have_attribute :metadata - end + it { is_expected.to have_readonly_attribute :uuid } + it { is_expected.to have_readonly_attribute :user_id } + it { is_expected.to have_readonly_attribute :asset_id } - # Updatable fields - it 'allows updating of read-write fields', :aggregate_failures do - expect(resource).to have_updatable_field :metadata - end - - it 'disallows updating of read-only fields', :aggregate_failures do - expect(resource).not_to have_updatable_field :id - expect(resource).not_to have_updatable_field :uuid - expect(resource).not_to have_updatable_field :user_id - expect(resource).not_to have_updatable_field :asset_id - end - - # Filters - # eg. it { is_expected.to filter(:order_type) } - - # Associations - # eg. it { is_expected.to have_many(:samples).with_class_name('Sample') } - - # Custom method tests - # Add tests for any custom methods you've added. + it { is_expected.to have_readwrite_attribute :metadata } end diff --git a/spec/resources/api/v2/labware_resource_spec.rb b/spec/resources/api/v2/labware_resource_spec.rb index 67186e12b6..1e82bbc23f 100644 --- a/spec/resources/api/v2/labware_resource_spec.rb +++ b/spec/resources/api/v2/labware_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::LabwareResource, type: :resource do subject(:resource) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :labware } + let(:resource_model) { build_stubbed(:labware) } shared_examples 'a labware resource' do # Test attributes diff --git a/spec/resources/api/v2/lane_resource_spec.rb b/spec/resources/api/v2/lane_resource_spec.rb index b64f22f802..212bbfede9 100644 --- a/spec/resources/api/v2/lane_resource_spec.rb +++ b/spec/resources/api/v2/lane_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::LaneResource, type: :resource do subject { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :lane } + let(:resource_model) { build_stubbed(:lane) } # Test attributes it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording diff --git a/spec/resources/api/v2/lot_resource_spec.rb b/spec/resources/api/v2/lot_resource_spec.rb index cfd5d78344..f303fda98a 100644 --- a/spec/resources/api/v2/lot_resource_spec.rb +++ b/spec/resources/api/v2/lot_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::LotResource, type: :resource do subject { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :lot } + let(:resource_model) { build_stubbed(:lot) } # Test attributes it 'has attributes', :aggregate_failures do diff --git a/spec/resources/api/v2/lot_type_resource_spec.rb b/spec/resources/api/v2/lot_type_resource_spec.rb index d32ae1fee1..74a907b06e 100644 --- a/spec/resources/api/v2/lot_type_resource_spec.rb +++ b/spec/resources/api/v2/lot_type_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::LotTypeResource, type: :resource do subject(:resource) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :lot_type, template_class: template_class } + let(:resource_model) { build_stubbed(:lot_type, template_class:) } let(:template_class) { 'TagLayoutTemplate' } # Test attributes diff --git a/spec/resources/api/v2/order_resource_spec.rb b/spec/resources/api/v2/order_resource_spec.rb index f0c56255ba..d6ee5b6719 100644 --- a/spec/resources/api/v2/order_resource_spec.rb +++ b/spec/resources/api/v2/order_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::OrderResource, type: :resource do subject { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :order } + let(:resource_model) { build_stubbed(:order) } # Test attributes it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording diff --git a/spec/resources/api/v2/pick_list_resource_spec.rb b/spec/resources/api/v2/pick_list_resource_spec.rb index b3e2cfd4d6..e6ee944fc4 100644 --- a/spec/resources/api/v2/pick_list_resource_spec.rb +++ b/spec/resources/api/v2/pick_list_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::PickListResource, :pick_list, type: :resource do subject(:resource) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :pick_list } + let(:resource_model) { build_stubbed(:pick_list) } # Read only attributes (almost certainly id) # Once again RSpec/ExampleLength cops war with RSpec/AggregateExamples diff --git a/spec/resources/api/v2/plate_resource_spec.rb b/spec/resources/api/v2/plate_resource_spec.rb index 4659c676a4..3b44e2dc34 100644 --- a/spec/resources/api/v2/plate_resource_spec.rb +++ b/spec/resources/api/v2/plate_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::PlateResource, type: :resource do subject(:resource) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :plate, barcode: 'SQPD-1', well_count: 3 } + let(:resource_model) { build_stubbed(:plate, barcode: 'SQPD-1', well_count: 3) } shared_examples 'a plate resource' do # Test attributes diff --git a/spec/resources/api/v2/plate_template_resource_spec.rb b/spec/resources/api/v2/plate_template_resource_spec.rb index 89c0955f88..83dcdbf7d5 100644 --- a/spec/resources/api/v2/plate_template_resource_spec.rb +++ b/spec/resources/api/v2/plate_template_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::PlateTemplateResource, type: :resource do subject(:resource) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :plate_template } + let(:resource_model) { build_stubbed(:plate_template) } # Test attributes it 'has the expected attributes', :aggregate_failures do diff --git a/spec/resources/api/v2/poly_metadatum_resource_spec.rb b/spec/resources/api/v2/poly_metadatum_resource_spec.rb index f06608189a..da1efc7a41 100644 --- a/spec/resources/api/v2/poly_metadatum_resource_spec.rb +++ b/spec/resources/api/v2/poly_metadatum_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::PolyMetadatumResource, type: :resource do subject(:metadatum_resource) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :poly_metadatum } + let(:resource_model) { build_stubbed(:poly_metadatum) } # Test attributes it 'works as expected', :aggregate_failures do diff --git a/spec/resources/api/v2/pooled_plate_creation_resource_spec.rb b/spec/resources/api/v2/pooled_plate_creation_resource_spec.rb new file mode 100644 index 0000000000..478c5e4d06 --- /dev/null +++ b/spec/resources/api/v2/pooled_plate_creation_resource_spec.rb @@ -0,0 +1,22 @@ +# frozen_string_literal: true + +require 'rails_helper' +require './app/resources/api/v2/pooled_plate_creation_resource' + +RSpec.describe Api::V2::PooledPlateCreationResource, type: :resource do + subject(:resource) { described_class.new(resource_model, {}) } + + let(:resource_model) { build_stubbed(:pooled_plate_creation) } + + # Attributes + it { is_expected.to have_readonly_attribute :uuid } + + it { is_expected.to have_writeonly_attribute :child_purpose_uuid } + it { is_expected.to have_writeonly_attribute :parent_uuids } + it { is_expected.to have_writeonly_attribute :user_uuid } + + # Relationships + it { is_expected.to have_one(:child).with_class_name('Plate') } + it { is_expected.to have_many(:parents).with_class_name('Labware') } + it { is_expected.to have_one(:user).with_class_name('User') } +end diff --git a/spec/resources/api/v2/pre_capture_pool_resource_spec.rb b/spec/resources/api/v2/pre_capture_pool_resource_spec.rb index 36f9f77451..b1ae416f5e 100644 --- a/spec/resources/api/v2/pre_capture_pool_resource_spec.rb +++ b/spec/resources/api/v2/pre_capture_pool_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::PreCapturePoolResource, type: :resource do subject { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :pre_capture_pool } + let(:resource_model) { build_stubbed(:pre_capture_pool) } # Test attributes it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording diff --git a/spec/resources/api/v2/primer_panel_resource_spec.rb b/spec/resources/api/v2/primer_panel_resource_spec.rb index 6f5637419f..5a9afa1aa9 100644 --- a/spec/resources/api/v2/primer_panel_resource_spec.rb +++ b/spec/resources/api/v2/primer_panel_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::PrimerPanelResource, type: :resource do subject { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :primer_panel } + let(:resource_model) { build_stubbed(:primer_panel) } # Test attributes it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording diff --git a/spec/resources/api/v2/project_resource_spec.rb b/spec/resources/api/v2/project_resource_spec.rb index 1cd8d53014..a1c3d08d31 100644 --- a/spec/resources/api/v2/project_resource_spec.rb +++ b/spec/resources/api/v2/project_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::SampleResource, type: :resource do subject { described_class.new(sample, {}) } - let(:sample) { create :sample } + let(:sample) { create(:sample) } it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording expect(subject).to have_attribute :sanger_sample_id diff --git a/spec/resources/api/v2/purpose_resource_spec.rb b/spec/resources/api/v2/purpose_resource_spec.rb index 9cca0287c2..9a4e47408d 100644 --- a/spec/resources/api/v2/purpose_resource_spec.rb +++ b/spec/resources/api/v2/purpose_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::PurposeResource, type: :resource do subject { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :purpose } + let(:resource_model) { build_stubbed(:purpose) } # Test attributes it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording diff --git a/spec/resources/api/v2/qcable_resource_spec.rb b/spec/resources/api/v2/qcable_resource_spec.rb index 71d4fd91aa..52e46c8eab 100644 --- a/spec/resources/api/v2/qcable_resource_spec.rb +++ b/spec/resources/api/v2/qcable_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::QcableResource, type: :resource do subject { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :qcable } + let(:resource_model) { build_stubbed(:qcable) } # Test attributes it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording diff --git a/spec/resources/api/v2/receptacle_resource_spec.rb b/spec/resources/api/v2/receptacle_resource_spec.rb index 310a4cc4e5..c992e6e011 100644 --- a/spec/resources/api/v2/receptacle_resource_spec.rb +++ b/spec/resources/api/v2/receptacle_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::ReceptacleResource, type: :resource do subject(:resource) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :receptacle } + let(:resource_model) { build_stubbed(:receptacle) } # Test attributes it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording diff --git a/spec/resources/api/v2/request_resource_spec.rb b/spec/resources/api/v2/request_resource_spec.rb index 23782cc69a..d9e81d28c3 100644 --- a/spec/resources/api/v2/request_resource_spec.rb +++ b/spec/resources/api/v2/request_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::RequestResource, type: :resource do subject { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :request } + let(:resource_model) { build_stubbed(:request) } # Test attributes let(:expected_metadata) { { 'customer_accepts_responsibility' => false } } @@ -34,8 +34,8 @@ end context 'isc request' do - let(:resource_model) { build_stubbed :isc_request, bait_library: bait_library } - let(:bait_library) { create :bait_library } + let(:resource_model) { build_stubbed(:isc_request, bait_library:) } + let(:bait_library) { create(:bait_library) } let(:expected_metadata) do { 'library_type' => 'Agilent Pulldown', diff --git a/spec/resources/api/v2/request_type_resource_spec.rb b/spec/resources/api/v2/request_type_resource_spec.rb index 0f7329d8a7..5d87343d34 100644 --- a/spec/resources/api/v2/request_type_resource_spec.rb +++ b/spec/resources/api/v2/request_type_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::RequestTypeResource, type: :resource do subject { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :request_type } + let(:resource_model) { build_stubbed(:request_type) } # Test attributes it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording diff --git a/spec/resources/api/v2/sample_resource_spec.rb b/spec/resources/api/v2/sample_resource_spec.rb index 5badaae453..248e392d85 100644 --- a/spec/resources/api/v2/sample_resource_spec.rb +++ b/spec/resources/api/v2/sample_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::SampleResource, type: :resource do subject { described_class.new(sample, {}) } - let(:sample) { create :sample } + let(:sample) { create(:sample) } it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording expect(subject).to have_attribute :sanger_sample_id diff --git a/spec/resources/api/v2/specific_tube_creation_resource_spec.rb b/spec/resources/api/v2/specific_tube_creation_resource_spec.rb new file mode 100644 index 0000000000..91b73e4f6c --- /dev/null +++ b/spec/resources/api/v2/specific_tube_creation_resource_spec.rb @@ -0,0 +1,23 @@ +# frozen_string_literal: true + +require 'rails_helper' +require './app/resources/api/v2/specific_tube_creation_resource' + +RSpec.describe Api::V2::SpecificTubeCreationResource, type: :resource do + subject(:resource) { described_class.new(resource_model, {}) } + + let(:resource_model) { build_stubbed(:specific_tube_creation) } + + # Attributes + it { is_expected.to have_readonly_attribute :uuid } + + it { is_expected.to have_writeonly_attribute :child_purpose_uuids } + it { is_expected.to have_writeonly_attribute :parent_uuids } + it { is_expected.to have_writeonly_attribute :tube_attributes } + it { is_expected.to have_writeonly_attribute :user_uuid } + + # Relationships + it { is_expected.to have_many(:children).with_class_name('Tube') } + it { is_expected.to have_many(:parents).with_class_name('Labware') } + it { is_expected.to have_one(:user).with_class_name('User') } +end diff --git a/spec/resources/api/v2/state_change_resource_spec.rb b/spec/resources/api/v2/state_change_resource_spec.rb index d985610dc6..91a4ce2af0 100644 --- a/spec/resources/api/v2/state_change_resource_spec.rb +++ b/spec/resources/api/v2/state_change_resource_spec.rb @@ -6,42 +6,21 @@ RSpec.describe Api::V2::StateChangeResource, type: :resource do subject(:resource) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :state_change } + let(:resource_model) { build_stubbed(:state_change) } # Attributes - it 'has the expected read-only attributes', :aggregate_failures do - expect(resource).to have_attribute :uuid - expect(resource).not_to have_updatable_field :uuid + it { is_expected.to have_readonly_attribute :uuid } + it { is_expected.to have_readonly_attribute :previous_state } - expect(resource).to have_attribute :previous_state - expect(resource).not_to have_updatable_field :previous_state - end + it { is_expected.to have_readwrite_attribute :contents } + it { is_expected.to have_readwrite_attribute :reason } + it { is_expected.to have_readwrite_attribute :target_state } - it 'has the expected read-write attributes', :aggregate_failures do - expect(resource).to have_attribute :contents - expect(resource).to have_updatable_field :contents - - expect(resource).to have_attribute :reason - expect(resource).to have_updatable_field :reason - - expect(resource).to have_attribute :target_state - expect(resource).to have_updatable_field :target_state - end - - it 'has the expected write-only attributes', :aggregate_failures do - expect(resource).not_to have_attribute :user_uuid - expect(resource).to have_updatable_field :user_uuid - - expect(resource).not_to have_attribute :target_uuid - expect(resource).to have_updatable_field :target_uuid - - expect(resource).not_to have_attribute :customer_accepts_responsibility - expect(resource).to have_updatable_field :customer_accepts_responsibility - end + it { is_expected.to have_writeonly_attribute :user_uuid } + it { is_expected.to have_writeonly_attribute :target_uuid } + it { is_expected.to have_writeonly_attribute :customer_accepts_responsibility } # Relationships - it 'has the expected relationships', :aggregate_failures do - expect(resource).to have_one(:target).with_class_name('Labware') - expect(resource).to have_one(:user).with_class_name('User') - end + it { is_expected.to have_one(:target).with_class_name('Labware') } + it { is_expected.to have_one(:user).with_class_name('User') } end diff --git a/spec/resources/api/v2/study_resource_spec.rb b/spec/resources/api/v2/study_resource_spec.rb index 78570bd11f..8876bd0dd8 100644 --- a/spec/resources/api/v2/study_resource_spec.rb +++ b/spec/resources/api/v2/study_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::StudyResource, type: :resource do subject { described_class.new(study, {}) } - let(:study) { create :study } + let(:study) { create(:study) } it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording expect(subject).to have_attribute :name diff --git a/spec/resources/api/v2/submission_resource_spec.rb b/spec/resources/api/v2/submission_resource_spec.rb index e8e0bc20e3..355dadd6f9 100644 --- a/spec/resources/api/v2/submission_resource_spec.rb +++ b/spec/resources/api/v2/submission_resource_spec.rb @@ -7,7 +7,7 @@ subject(:resource) { described_class.new(resource_model, {}) } let(:sequencing_requests) { build_stubbed_list(:sequencing_request, 3) } - let(:resource_model) { build_stubbed :submission, sequencing_requests: sequencing_requests } + let(:resource_model) { build_stubbed(:submission, sequencing_requests:) } # Test attributes it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording diff --git a/spec/resources/api/v2/submission_template_resource_spec.rb b/spec/resources/api/v2/submission_template_resource_spec.rb index 7f1a8f39db..f9f9546280 100644 --- a/spec/resources/api/v2/submission_template_resource_spec.rb +++ b/spec/resources/api/v2/submission_template_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::SubmissionTemplateResource, type: :resource do subject(:resource) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :submission_template } + let(:resource_model) { build_stubbed(:submission_template) } # Test attributes it 'has the expected attributes', :aggregate_failures do diff --git a/spec/resources/api/v2/tag_group_resource_spec.rb b/spec/resources/api/v2/tag_group_resource_spec.rb index 6c61f3bfd5..ff4f4e21bb 100644 --- a/spec/resources/api/v2/tag_group_resource_spec.rb +++ b/spec/resources/api/v2/tag_group_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::TagGroupResource, type: :resource do subject { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :tag_group, tags: tags } + let(:resource_model) { build_stubbed(:tag_group, tags:) } let(:tags) do [ build(:tag, oligo: 'AAA', map_id: 1), diff --git a/spec/resources/api/v2/tag_layout_resource_spec.rb b/spec/resources/api/v2/tag_layout_resource_spec.rb new file mode 100644 index 0000000000..87a0cafc66 --- /dev/null +++ b/spec/resources/api/v2/tag_layout_resource_spec.rb @@ -0,0 +1,30 @@ +# frozen_string_literal: true + +require 'rails_helper' +require './app/resources/api/v2/tag_layout_resource' + +RSpec.describe Api::V2::TagLayoutResource, type: :resource do + subject(:resource) { described_class.new(resource_model, {}) } + + let(:resource_model) { build_stubbed(:tag_layout) } + + # Attributes + it { is_expected.to have_readonly_attribute :uuid } + + it { is_expected.to have_readwrite_attribute :direction } + it { is_expected.to have_readwrite_attribute :initial_tag } + it { is_expected.to have_readwrite_attribute :substitutions } + it { is_expected.to have_readwrite_attribute :tags_per_well } + it { is_expected.to have_readwrite_attribute :walking_by } + + it { is_expected.to have_writeonly_attribute :plate_uuid } + it { is_expected.to have_writeonly_attribute :tag_group_uuid } + it { is_expected.to have_writeonly_attribute :tag2_group_uuid } + it { is_expected.to have_writeonly_attribute :user_uuid } + + # Relationships + it { is_expected.to have_one(:plate).with_class_name('Plate') } + it { is_expected.to have_one(:tag_group).with_class_name('TagGroup') } + it { is_expected.to have_one(:tag2_group).with_class_name('TagGroup') } + it { is_expected.to have_one(:user).with_class_name('User') } +end diff --git a/spec/resources/api/v2/tag_layout_template_resource_spec.rb b/spec/resources/api/v2/tag_layout_template_resource_spec.rb index c01091e1f3..3956b049e1 100644 --- a/spec/resources/api/v2/tag_layout_template_resource_spec.rb +++ b/spec/resources/api/v2/tag_layout_template_resource_spec.rb @@ -6,28 +6,18 @@ RSpec.describe Api::V2::TagLayoutTemplateResource, type: :resource do subject(:resource) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :tag_layout_template } + let(:resource_model) { build_stubbed(:tag_layout_template) } - # Expected attributes - it { is_expected.not_to have_attribute :id } - it { is_expected.to have_attribute :uuid } - it { is_expected.to have_attribute :name } - it { is_expected.to have_attribute :direction } - it { is_expected.to have_attribute :walking_by } - - # Read-only fields - it { is_expected.not_to have_updatable_field :uuid } - it { is_expected.not_to have_updatable_field :name } - it { is_expected.not_to have_updatable_field :direction } - it { is_expected.not_to have_updatable_field :walking_by } + # Attributes + it { is_expected.to have_readonly_attribute :uuid } + it { is_expected.to have_readonly_attribute :name } + it { is_expected.to have_readonly_attribute :direction } + it { is_expected.to have_readonly_attribute :walking_by } # Filters it { is_expected.to filter(:enabled) } - # Associations + # Relationships it { is_expected.to have_one(:tag_group).with_class_name('TagGroup') } it { is_expected.to have_one(:tag2_group).with_class_name('TagGroup') } - - # Custom method tests - # Add tests for any custom methods you've added. end diff --git a/spec/resources/api/v2/tag_resource_spec.rb b/spec/resources/api/v2/tag_resource_spec.rb index 6f60b4d1db..3a1b003fd3 100644 --- a/spec/resources/api/v2/tag_resource_spec.rb +++ b/spec/resources/api/v2/tag_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::TagResource, type: :resource do subject(:tag_resource) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :tag } + let(:resource_model) { build_stubbed(:tag) } # Test attributes it 'works', :aggregate_failures do # rubocop:todo RSpec/ExampleWording diff --git a/spec/resources/api/v2/transfer_request_resource_spec.rb b/spec/resources/api/v2/transfer_request_resource_spec.rb index 51b552bed4..7cd1a205cb 100644 --- a/spec/resources/api/v2/transfer_request_resource_spec.rb +++ b/spec/resources/api/v2/transfer_request_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::TransferRequestResource, type: :resource do subject(:transfer_request) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :transfer_request } + let(:resource_model) { build_stubbed(:transfer_request) } it 'exposes attributes', :aggregate_failures do # Test attributes diff --git a/spec/resources/api/v2/transfer_template_resource_spec.rb b/spec/resources/api/v2/transfer_template_resource_spec.rb index adb61a50c7..107bce78eb 100644 --- a/spec/resources/api/v2/transfer_template_resource_spec.rb +++ b/spec/resources/api/v2/transfer_template_resource_spec.rb @@ -6,30 +6,12 @@ RSpec.describe Api::V2::TransferTemplateResource, type: :resource do subject(:resource) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :transfer_template } + let(:resource_model) { build_stubbed(:transfer_template) } - # Test attributes - it 'has the expected attributes', :aggregate_failures do - expect(resource).not_to have_attribute :id - expect(resource).to have_attribute :uuid - expect(resource).to have_attribute :name - end - - # Updatable fields - it 'allows updating of read-write fields', :aggregate_failures do - expect(resource).to have_updatable_field :name - end - - it 'disallows updating of read-only fields', :aggregate_failures do - expect(resource).not_to have_updatable_field :uuid - end + # Attributes + it { is_expected.to have_readonly_attribute :uuid } + it { is_expected.to have_readwrite_attribute :name } # Filters it { is_expected.to filter(:uuid) } - - # Associations - # eg. it { is_expected.to have_many(:samples).with_class_name('Sample') } - - # Custom method tests - # Add tests for any custom methods you've added. end diff --git a/spec/resources/api/v2/transfers/transfer_resource_spec.rb b/spec/resources/api/v2/transfers/transfer_resource_spec.rb index 54fc4a02a1..e63cd10711 100644 --- a/spec/resources/api/v2/transfers/transfer_resource_spec.rb +++ b/spec/resources/api/v2/transfers/transfer_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::Transfers::TransferResource, type: :resource do subject(:resource) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :transfer_between_plates } + let(:resource_model) { build_stubbed(:transfer_between_plates) } # Test attributes it 'allows fetching the expected attributes', :aggregate_failures do diff --git a/spec/resources/api/v2/tube_purpose_resource_spec.rb b/spec/resources/api/v2/tube_purpose_resource_spec.rb index 8dff614633..6b274c9004 100644 --- a/spec/resources/api/v2/tube_purpose_resource_spec.rb +++ b/spec/resources/api/v2/tube_purpose_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::TubePurposeResource, type: :resource do subject(:resource) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :tube_purpose } + let(:resource_model) { build_stubbed(:tube_purpose) } # Test attributes it 'has the expected attributes', :aggregate_failures do diff --git a/spec/resources/api/v2/tube_rack_resource_spec.rb b/spec/resources/api/v2/tube_rack_resource_spec.rb index 3877257c99..89e9f4f6c5 100644 --- a/spec/resources/api/v2/tube_rack_resource_spec.rb +++ b/spec/resources/api/v2/tube_rack_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::TubeRackResource, type: :resource do subject(:tube_rack) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :tube_rack } + let(:resource_model) { build_stubbed(:tube_rack) } # Test attributes it 'has attributes', :aggregate_failures do @@ -40,8 +40,8 @@ # Add tests for any custom methods you've added. describe 'tube_locations=' do - let(:a1_tube) { create :tube } - let(:b1_tube) { create :tube } + let(:a1_tube) { create(:tube) } + let(:b1_tube) { create(:tube) } let(:new_locations) { { A1: { uuid: a1_tube.uuid }, B1: { uuid: b1_tube.uuid } } } it 'adds associations for the two tubes' do diff --git a/spec/resources/api/v2/tube_resource_spec.rb b/spec/resources/api/v2/tube_resource_spec.rb index ab049b52c1..e6bb581770 100644 --- a/spec/resources/api/v2/tube_resource_spec.rb +++ b/spec/resources/api/v2/tube_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::TubeResource, type: :resource do subject(:resource) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :tube, barcode_number: 1 } + let(:resource_model) { build_stubbed(:tube, barcode_number: 1) } # Test attributes it 'exposes the expected data', :aggregate_failures do diff --git a/spec/resources/api/v2/user_resource_spec.rb b/spec/resources/api/v2/user_resource_spec.rb index 233ea86fd1..0983c96a04 100644 --- a/spec/resources/api/v2/user_resource_spec.rb +++ b/spec/resources/api/v2/user_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::UserResource, type: :resource do subject(:resource) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :user } + let(:resource_model) { build_stubbed(:user) } # Expected attributes it { is_expected.not_to have_attribute :id } diff --git a/spec/resources/api/v2/well_resource_spec.rb b/spec/resources/api/v2/well_resource_spec.rb index 83147eaeb9..29525ee0d3 100644 --- a/spec/resources/api/v2/well_resource_spec.rb +++ b/spec/resources/api/v2/well_resource_spec.rb @@ -6,7 +6,7 @@ RSpec.describe Api::V2::WellResource, type: :resource do subject(:resource) { described_class.new(resource_model, {}) } - let(:resource_model) { build_stubbed :well, plate: plate, map: position } + let(:resource_model) { build_stubbed(:well, plate: plate, map: position) } shared_examples 'a well resource' do # Test attributes @@ -54,8 +54,8 @@ end context 'on a plate' do - let(:plate) { create :plate, barcode: 'SQPD-1' } - let(:position) { create :map, description: 'A1' } + let(:plate) { create(:plate, barcode: 'SQPD-1') } + let(:position) { create(:map, description: 'A1') } let(:expected_barcode_hash) { { 'ean13_barcode' => nil, 'human_barcode' => 'SQPD-1' } } let(:expected_position) { { 'name' => 'A1' } } diff --git a/spec/resources/api/v2/work_order_resource_spec.rb b/spec/resources/api/v2/work_order_resource_spec.rb index bcf6afa6f2..245f994660 100644 --- a/spec/resources/api/v2/work_order_resource_spec.rb +++ b/spec/resources/api/v2/work_order_resource_spec.rb @@ -7,7 +7,7 @@ shared_examples_for 'a work order resource' do subject { described_class.new(work_order, {}) } - let(:work_order) { create(:work_order, requests: requests).reload } + let(:work_order) { create(:work_order, requests:).reload } it { is_expected.to have_attribute :order_type } it { is_expected.to have_attribute :state } diff --git a/spec/sample_manifest_excel/upload/data_spec.rb b/spec/sample_manifest_excel/upload/data_spec.rb index 46e911bdc7..b1bbeb7c2d 100644 --- a/spec/sample_manifest_excel/upload/data_spec.rb +++ b/spec/sample_manifest_excel/upload/data_spec.rb @@ -13,7 +13,7 @@ let(:test_file_name) { 'test_file.xlsx' } let(:test_file) { Rack::Test::UploadedFile.new(Rails.root.join(test_file_name), '') } let(:columns) { SampleManifestExcel.configuration.columns.tube_library_with_tag_sequences.dup } - let!(:download) { build(:test_download_tubes, columns: columns) } + let!(:download) { build(:test_download_tubes, columns:) } before { download.save(test_file_name) } diff --git a/spec/sample_manifest_excel/upload/processor_spec.rb b/spec/sample_manifest_excel/upload/processor_spec.rb index 1faa5aea8d..0d5e2332b2 100644 --- a/spec/sample_manifest_excel/upload/processor_spec.rb +++ b/spec/sample_manifest_excel/upload/processor_spec.rb @@ -157,7 +157,7 @@ def cell(row, column) # This test may seem a little paranoid, but I actually observed this behaviour # when testing. Somewhat lucky, as I only triggered it by accident! it 'will update the aliquots downstream if both tags and library types have changed' do - new_lt = create :library_type + new_lt = create(:library_type) chromium_tag1 = cell(rows.first, columns[:chromium_tag_well]).value chromium_tag2 = cell(rows.last, columns[:chromium_tag_well]).value cell(rows.first, columns[:chromium_tag_well]).value = chromium_tag2 @@ -1167,7 +1167,7 @@ def cell(row, column) context 'when the tube barcode exists already' do let(:no_of_racks) { 1 } let(:no_of_rows) { 2 } - let(:tube) { create :tube } + let(:tube) { create(:tube) } before { Barcode.create!(asset_id: tube.id, barcode: 'TB11111110', format: 'fluidx_barcode') } diff --git a/spec/sample_manifest_excel/upload/row_spec.rb b/spec/sample_manifest_excel/upload/row_spec.rb index 9dcca8dfda..0c4f8b25c7 100644 --- a/spec/sample_manifest_excel/upload/row_spec.rb +++ b/spec/sample_manifest_excel/upload/row_spec.rb @@ -104,7 +104,7 @@ it 'is not valid without row number' do expect(described_class.new(number: 'one', data: data, columns: columns)).not_to be_valid - expect(described_class.new(data: data, columns: columns)).not_to be_valid + expect(described_class.new(data:, columns:)).not_to be_valid end it 'is not valid without some data' do @@ -364,7 +364,7 @@ let(:library_tubes) { create_list(:empty_library_tube, 5) } let(:mx_library_tube) { create(:multiplexed_library_tube) } let(:tags) { SampleManifestExcel::Tags::ExampleData.new.take(0, 4) } - let(:manifest) { create :sample_manifest, asset_type: 'multiplexed_library' } + let(:manifest) { create(:sample_manifest, asset_type: 'multiplexed_library') } before do @rows = [] @@ -406,7 +406,7 @@ let(:library_tubes) { create_list(:tagged_library_tube, 5) } let(:mx_library_tube) { create(:multiplexed_library_tube) } let(:tags) { SampleManifestExcel::Tags::ExampleData.new.take(0, 4) } - let(:manifest) { create :sample_manifest, asset_type: 'library' } + let(:manifest) { create(:sample_manifest, asset_type: 'library') } before do @rows = [] diff --git a/spec/sample_manifest_excel/upload/rows_spec.rb b/spec/sample_manifest_excel/upload/rows_spec.rb index 8d3ef7fa08..928638f15e 100644 --- a/spec/sample_manifest_excel/upload/rows_spec.rb +++ b/spec/sample_manifest_excel/upload/rows_spec.rb @@ -23,7 +23,7 @@ end it 'is not valid without some columns' do - download = build(:test_download_tubes, columns: columns) + download = build(:test_download_tubes, columns:) download.save(test_file_name) expect(described_class.new(SampleManifestExcel::Upload::Data.new(test_file), nil)).not_to be_valid end @@ -35,7 +35,7 @@ end it 'is valid if some rows are empty' do - download = build(:test_download_tubes_partial, columns: columns) + download = build(:test_download_tubes_partial, columns:) download.save(test_file_name) expect(described_class.new(SampleManifestExcel::Upload::Data.new(test_file), columns)).to be_valid end diff --git a/spec/sample_manifest_excel/upload/upload_spec.rb b/spec/sample_manifest_excel/upload/upload_spec.rb index 4833e3b5d5..d2c9adb177 100644 --- a/spec/sample_manifest_excel/upload/upload_spec.rb +++ b/spec/sample_manifest_excel/upload/upload_spec.rb @@ -10,7 +10,7 @@ end end - let(:user) { create :user, login: 'test_user' } + let(:user) { create(:user, login: 'test_user') } let(:test_file_name) { 'test_file.xlsx' } let(:test_file) { Rack::Test::UploadedFile.new(Rails.root.join(test_file_name), '') } let!(:tag_group) { create(:tag_group) } @@ -133,7 +133,7 @@ describe '#processor' do context '1dtube' do let!(:columns) { SampleManifestExcel.configuration.columns.tube_full.dup } - let!(:download) { build(:test_download_tubes, columns: columns) } + let!(:download) { build(:test_download_tubes, columns:) } let(:upload) { SampleManifestExcel::Upload::Base.new(file: test_file, column_list: columns, start_row: 9) } before { download.save(test_file_name) } diff --git a/spec/sample_manifest_excel/worksheet_spec.rb b/spec/sample_manifest_excel/worksheet_spec.rb index 7910a82b6b..b77883e4d1 100644 --- a/spec/sample_manifest_excel/worksheet_spec.rb +++ b/spec/sample_manifest_excel/worksheet_spec.rb @@ -24,7 +24,7 @@ def save_file before do allow(PlateBarcode).to receive(:create_barcode).and_return(build(:plate_barcode)) - @sample_manifest = create :sample_manifest + @sample_manifest = create(:sample_manifest) sample_manifest.generate end diff --git a/spec/sequencescape_excel/column_spec.rb b/spec/sequencescape_excel/column_spec.rb index 9453a9c737..769fafc734 100644 --- a/spec/sequencescape_excel/column_spec.rb +++ b/spec/sequencescape_excel/column_spec.rb @@ -199,7 +199,7 @@ end describe '#style' do - subject { described_class.new({ **options, unlocked: unlocked }).style } + subject { described_class.new({ **options, unlocked: }).style } context 'when locked' do let(:unlocked) { false } diff --git a/spec/sequencescape_excel/conditional_formatting_list_spec.rb b/spec/sequencescape_excel/conditional_formatting_list_spec.rb index f97f1ebbb9..586b74b661 100644 --- a/spec/sequencescape_excel/conditional_formatting_list_spec.rb +++ b/spec/sequencescape_excel/conditional_formatting_list_spec.rb @@ -9,7 +9,7 @@ let(:rules) { load_file(folder, 'conditional_formattings') } let(:conditional_formatting_list) { described_class.new(rules) } let(:worksheet) { Axlsx::Workbook.new.add_worksheet } - let(:options) { build(:range).references.merge(worksheet: worksheet) } + let(:options) { build(:range).references.merge(worksheet:) } it 'must have the correct number of options' do expect(conditional_formatting_list.count).to eq(rules.length) diff --git a/spec/sequencescape_excel/conditional_formatting_spec.rb b/spec/sequencescape_excel/conditional_formatting_spec.rb index bfa5c1920d..792dedb008 100644 --- a/spec/sequencescape_excel/conditional_formatting_spec.rb +++ b/spec/sequencescape_excel/conditional_formatting_spec.rb @@ -48,7 +48,7 @@ end it 'update the style from a workbook' do - expect(conditional_formatting.update(worksheet: worksheet)).to be_styled + expect(conditional_formatting.update(worksheet:)).to be_styled end it '#to_h produces a hash of options' do @@ -58,7 +58,7 @@ it 'duplicates correctly' do dup = conditional_formatting.dup expect(dup.formula).to be_nil - conditional_formatting.update(worksheet: worksheet) + conditional_formatting.update(worksheet:) expect(dup).not_to be_styled end end @@ -66,7 +66,7 @@ context 'with formula' do let(:references) { build(:range).references } let(:formula) { { type: :len, operator: '<', operand: 333 } } - let(:conditional_formatting) { described_class.new(rule.merge(formula: formula)) } + let(:conditional_formatting) { described_class.new(rule.merge(formula:)) } it 'has a formula' do expect(conditional_formatting.formula).to eq(SequencescapeExcel::Formula.new(formula)) @@ -83,12 +83,12 @@ end it 'update the style from a worksheet' do - expect(conditional_formatting.update(references.merge(worksheet: worksheet))).to be_styled + expect(conditional_formatting.update(references.merge(worksheet:))).to be_styled end it 'duplicate correctly' do dup = conditional_formatting.dup - conditional_formatting.update(references.merge(worksheet: worksheet)) + conditional_formatting.update(references.merge(worksheet:)) expect(dup.options).not_to eq(conditional_formatting.options) expect(dup.formula).not_to eq(conditional_formatting.formula) end diff --git a/spec/sequencescape_excel/range_spec.rb b/spec/sequencescape_excel/range_spec.rb index 49acf82e95..aa0a3d55dd 100644 --- a/spec/sequencescape_excel/range_spec.rb +++ b/spec/sequencescape_excel/range_spec.rb @@ -79,7 +79,7 @@ context 'with dynamic options' do # Ensure we have at least one option. - before { create :library_type } + before { create(:library_type) } let!(:original_option_size) { LibraryType.count } let(:attributes) { { name: 'library_type', identifier: :name, scope: :alphabetical, first_row: 4 } } @@ -142,7 +142,7 @@ it 'adjusts to changes in option number' do previous_last_cell = range.last_cell.column - create :library_type, name: 'Other' + create(:library_type, name: 'Other') expect(range.last_column).to eq(original_option_size + 1) expect(range.last_cell.column).to eq(previous_last_cell.next) end @@ -161,7 +161,7 @@ end context 'without first row' do - let(:range) { described_class.new(options: options) } + let(:range) { described_class.new(options:) } it 'is be valid' do expect(range).not_to be_valid diff --git a/spec/sequencescape_excel/specialised_field_spec.rb b/spec/sequencescape_excel/specialised_field_spec.rb index 6079b25665..bf8eb0d63e 100644 --- a/spec/sequencescape_excel/specialised_field_spec.rb +++ b/spec/sequencescape_excel/specialised_field_spec.rb @@ -4,26 +4,30 @@ RSpec.describe SequencescapeExcel::SpecialisedField, :sample_manifest, :sample_manifest_excel, type: :model do let(:map) { create(:map) } - let(:asset) { create(:untagged_well, map: map) } - let(:asset2) { create(:untagged_well, map: map) } - let(:sample_manifest) { create :sample_manifest } + let(:asset) { create(:untagged_well, map:) } + let(:asset2) { create(:untagged_well, map:) } + let(:sample_manifest) { create(:sample_manifest) } let(:sample_manifest_asset) do - create :sample_manifest_asset, - asset: asset, - sanger_sample_id: sample.sanger_sample_id, - sample_manifest: sample_manifest + create( + :sample_manifest_asset, + asset: asset, + sanger_sample_id: sample.sanger_sample_id, + sample_manifest: sample_manifest + ) end let(:sample_manifest_asset2) do - create :sample_manifest_asset, - asset: asset2, - sanger_sample_id: sample2.sanger_sample_id, - sample_manifest: sample_manifest + create( + :sample_manifest_asset, + asset: asset2, + sanger_sample_id: sample2.sanger_sample_id, + sample_manifest: sample_manifest + ) end let!(:library_type) { create(:library_type) } let!(:reference_genome) { create(:reference_genome, name: 'new one') } let(:aliquot) { sample_manifest_asset.asset.aliquots.first } - let(:sample) { create :sample_with_sanger_sample_id } - let(:sample2) { create :sample_with_sanger_sample_id } + let(:sample) { create(:sample_with_sanger_sample_id) } + let(:sample2) { create(:sample_with_sanger_sample_id) } describe SequencescapeExcel::SpecialisedField::Base do # We use an anonymous class as classes created in specs have global scope. @@ -37,7 +41,7 @@ end it 'knows if value is present' do - thing = class_with_base.new(sample_manifest_asset: sample_manifest_asset) + thing = class_with_base.new(sample_manifest_asset:) expect(thing).not_to be_value_present thing.value = 'value' expect(thing).to be_value_present @@ -75,7 +79,7 @@ def self.name it 'will add the the value to the aliquot' do specialised_field = described_class.new(value: library_type.name, sample_manifest_asset: sample_manifest_asset) - specialised_field.update(aliquot: aliquot) + specialised_field.update(aliquot:) expect(aliquot.library_type).to eq(library_type.name) end @@ -84,7 +88,7 @@ def self.name it 'will add the the value to all aliquots' do specialised_field = described_class.new(value: library_type.name, sample_manifest_asset: sample_manifest_asset) - specialised_field.update(aliquot: aliquot) + specialised_field.update(aliquot:) expect(asset.aliquots).to all(have_attributes(library_type: library_type.name)) end end @@ -92,7 +96,7 @@ def self.name describe SequencescapeExcel::SpecialisedField::ReferenceGenome do it 'is valid, if a value was not provided' do - expect(described_class.new(sample_manifest_asset: sample_manifest_asset)).to be_valid + expect(described_class.new(sample_manifest_asset:)).to be_valid end it 'will not be valid without a persisted reference genome if a value is provided' do @@ -117,13 +121,13 @@ def self.name let(:value2) { '8' } it 'will update the volume in sample metadata' do - specialised_field = described_class.new(value: value, sample_manifest_asset: sample_manifest_asset) + specialised_field = described_class.new(value:, sample_manifest_asset:) specialised_field.update expect(sample_manifest_asset.sample.sample_metadata.volume).to eq(value) end it 'will create a QC result for the asset' do - specialised_field = described_class.new(value: value, sample_manifest_asset: sample_manifest_asset) + specialised_field = described_class.new(value:, sample_manifest_asset:) specialised_field.update qc_result = sample_manifest_asset.asset.qc_results.first expect(qc_result.value).to eq(value.to_f.to_s) @@ -133,7 +137,7 @@ def self.name end it 'will create a QC assay for each sample manifest' do - specialised_field1 = described_class.new(value: value, sample_manifest_asset: sample_manifest_asset) + specialised_field1 = described_class.new(value:, sample_manifest_asset:) specialised_field1.update specialised_field2 = described_class.new(value: value2, sample_manifest_asset: sample_manifest_asset2) specialised_field2.update @@ -167,7 +171,7 @@ def self.name it 'will add the value to the aliquot' do specialised_field = described_class.new(value: 100, sample_manifest_asset: sample_manifest_asset) - specialised_field.update(aliquot: aliquot) + specialised_field.update(aliquot:) expect(aliquot.insert_size_from).to eq(100) end @@ -176,7 +180,7 @@ def self.name it 'will add the the value to all aliquots' do specialised_field = described_class.new(value: 100, sample_manifest_asset: sample_manifest_asset) - specialised_field.update(aliquot: aliquot) + specialised_field.update(aliquot:) expect(asset.aliquots).to all(have_attributes(insert_size_from: 100)) end end @@ -190,7 +194,7 @@ def self.name it 'will add the value to the aliquot' do specialised_field = described_class.new(value: 100, sample_manifest_asset: sample_manifest_asset) - specialised_field.update(aliquot: aliquot) + specialised_field.update(aliquot:) expect(aliquot.insert_size_to).to eq(100) end @@ -199,7 +203,7 @@ def self.name it 'will add the the value to all aliquots' do specialised_field = described_class.new(value: 100, sample_manifest_asset: sample_manifest_asset) - specialised_field.update(aliquot: aliquot) + specialised_field.update(aliquot:) expect(asset.aliquots).to all(have_attributes(insert_size_to: 100)) end end @@ -208,7 +212,7 @@ def self.name describe SequencescapeExcel::SpecialisedField::SangerPlateId do let!(:sample1) { create(:sample_with_well) } let!(:sample1_plate) { sample1.wells.first.plate } - let(:sample_manifest_asset1) { create :sample_manifest_asset, asset: sample1.primary_receptacle } + let(:sample_manifest_asset1) { create(:sample_manifest_asset, asset: sample1.primary_receptacle) } it 'will be valid if the value matches the sanger human barcode' do expect( @@ -219,7 +223,7 @@ def self.name describe 'with foreign barcodes' do let!(:sample2) { create(:sample_with_well) } - let(:sample_manifest_asset2) { create :sample_manifest_asset, asset: sample2.primary_receptacle } + let(:sample_manifest_asset2) { create(:sample_manifest_asset, asset: sample2.primary_receptacle) } it 'will be valid if the value matches an unused cgap foreign barcode' do expect(described_class.new(value: 'CGAP-ABC001', sample_manifest_asset: sample_manifest_asset1)).to be_valid @@ -254,7 +258,7 @@ def self.name let!(:sample1) { create(:sample) } let!(:sample1_tube) { create(:sample_tube_with_sanger_sample_id, sample: sample1) } - let(:manifest_asset) { create :sample_manifest_asset, asset: sample1_tube } + let(:manifest_asset) { create(:sample_manifest_asset, asset: sample1_tube) } it 'will be valid if the value matches the sanger human barcode' do expect(described_class.new(value: sample1_tube.human_barcode, sample_manifest_asset: manifest_asset)).to be_valid @@ -264,7 +268,7 @@ def self.name describe 'with foreign barcodes' do let!(:sample2) { create(:sample) } let!(:sample2_tube) { create(:sample_tube_with_sanger_sample_id, sample: sample2) } - let(:manifest_asset2) { create :sample_manifest_asset, asset: sample2_tube } + let(:manifest_asset2) { create(:sample_manifest_asset, asset: sample2_tube) } it 'will be valid if the value matches an unused cgap foreign barcode' do expect(described_class.new(value: 'CGAP-ABC001', sample_manifest_asset: manifest_asset)).to be_valid @@ -338,8 +342,8 @@ def self.name end it 'will update the aliquot and create the tag if oligo is present' do - i7.update(aliquot: aliquot, tag_group: tag_group) - tag = tag_group.tags.find_by(oligo: oligo) + i7.update(aliquot:, tag_group:) + tag = tag_group.tags.find_by(oligo:) expect(tag).to be_present expect(tag.oligo).to eq(oligo) expect(tag.map_id).to eq(1) @@ -348,14 +352,14 @@ def self.name it 'if oligo is not present aliquot tag should be -1' do i7 = described_class.new(value: nil, sample_manifest_asset: sample_manifest_asset) - i7.update(aliquot: aliquot, tag_group: tag_group) + i7.update(aliquot:, tag_group:) aliquot.save expect(aliquot.tag_id).to eq(-1) end it 'will find the tag if it already exists' do tag = tag_group.tags.create(oligo: oligo, map_id: 10) - i7.update(aliquot: aliquot, tag_group: tag_group) + i7.update(aliquot:, tag_group:) expect(aliquot.tag).to eq(tag) end end @@ -373,9 +377,9 @@ def self.name end it 'will update the aliquot' do - i5.update(aliquot: aliquot, tag_group: tag_group) + i5.update(aliquot:, tag_group:) aliquot.save - expect(aliquot.tag2).to eq(tag_group.tags.find_by(oligo: oligo)) + expect(aliquot.tag2).to eq(tag_group.tags.find_by(oligo:)) end end end @@ -507,7 +511,7 @@ def self.name it 'does not retrieve nil tag' do expect(sf_tag2_index).to be_valid - sf_tag2_index.update(aliquot: aliquot) + sf_tag2_index.update(aliquot:) expect(aliquot.tag2_id).to eq(-1) end end @@ -558,8 +562,8 @@ def self.name end describe SequencescapeExcel::SpecialisedField::ChromiumTagGroup do - let(:adapter_type) { create :adapter_type, name: 'Chromium' } - let(:tag_group) { create(:tag_group_with_tags, adapter_type: adapter_type) } + let(:adapter_type) { create(:adapter_type, name: 'Chromium') } + let(:tag_group) { create(:tag_group_with_tags, adapter_type:) } let(:tag_group_name) { tag_group.name } let(:tag_well) { 'A1' } @@ -574,7 +578,7 @@ def self.name end context 'when the tag group is not Chromium' do - let(:adapter_type) { create :adapter_type, name: 'Other' } + let(:adapter_type) { create(:adapter_type, name: 'Other') } it 'will not be valid' do expect( @@ -642,9 +646,9 @@ def self.name end describe SequencescapeExcel::SpecialisedField::DualIndexTagSet do - let(:tag_group1) { create :tag_group_with_tags } - let(:tag_group2) { create :tag_group_with_tags } - let(:dual_index_tag_set) { create :tag_set, tag_group: tag_group1, tag2_group: tag_group2 } + let(:tag_group1) { create(:tag_group_with_tags) } + let(:tag_group2) { create(:tag_group_with_tags) } + let(:dual_index_tag_set) { create(:tag_set, tag_group: tag_group1, tag2_group: tag_group2) } let(:dual_index_tag_well) { 'A1' } describe 'dual index tag set' do @@ -683,7 +687,7 @@ def self.name end context 'when the tag set name is has only one visible tag group' do - let(:tag_group2) { create :tag_group_with_tags, visible: false } + let(:tag_group2) { create(:tag_group_with_tags, visible: false) } it 'will be not be valid' do expect(sf_dual_index_tag_set).not_to be_valid @@ -773,7 +777,7 @@ def self.name end describe SequencescapeExcel::SpecialisedField::PrimerPanel do - let(:primer_panel) { create :primer_panel } + let(:primer_panel) { create(:primer_panel) } it 'will not be valid without a persisted primer panel' do expect(described_class.new(value: primer_panel.name, sample_manifest_asset: sample_manifest_asset)).to be_valid @@ -788,7 +792,7 @@ def self.name it 'will add the the value to the aliquot' do specialised_field = described_class.new(value: primer_panel.name, sample_manifest_asset: sample_manifest_asset) - specialised_field.update(aliquot: aliquot) + specialised_field.update(aliquot:) expect(aliquot.primer_panel).to eq(primer_panel) end @@ -797,8 +801,8 @@ def self.name it 'will add the the value to all aliquots' do specialised_field = described_class.new(value: primer_panel.name, sample_manifest_asset: sample_manifest_asset) - specialised_field.update(aliquot: aliquot) - expect(asset.aliquots).to all(have_attributes(primer_panel: primer_panel)) + specialised_field.update(aliquot:) + expect(asset.aliquots).to all(have_attributes(primer_panel:)) end end end @@ -824,7 +828,7 @@ def self.name it 'will update the priority on the sample when present' do specialised_field = described_class.new(value: '1', sample_manifest_asset: sample_manifest_asset) - specialised_field.update(aliquot: aliquot) + specialised_field.update(aliquot:) aliquot.save expect(sample_manifest_asset.sample.priority).to eq('backlog') end @@ -849,7 +853,7 @@ def self.name it 'will update the control and control type on the sample when present' do specialised_field = described_class.new(value: 'positive', sample_manifest_asset: sample_manifest_asset) - specialised_field.update(aliquot: aliquot) + specialised_field.update(aliquot:) aliquot.save expect(sample_manifest_asset.sample.control).to be(true) expect(sample_manifest_asset.sample.control_type).to eq('positive') @@ -861,7 +865,7 @@ def self.name sample_manifest_asset.sample.control_type = 'positive' sample_manifest_asset.sample.save specialised_field = described_class.new(value: '', sample_manifest_asset: sample_manifest_asset) - specialised_field.update(aliquot: aliquot) + specialised_field.update(aliquot:) aliquot.save expect(sample_manifest_asset.sample.control).to be(false) expect(sample_manifest_asset.sample.control_type).to be_nil @@ -911,7 +915,7 @@ def self.name it 'will update the control and control type on the sample when present' do sf = described_class.new(value: 'pcr positive', sample_manifest_asset: sample_manifest_asset) sf.supplier_name = bs_supplier_name - sf.update(aliquot: aliquot) + sf.update(aliquot:) aliquot.save expect(sample_manifest_asset.sample.control).to be(true) expect(sample_manifest_asset.sample.control_type).to eq('pcr positive') @@ -924,7 +928,7 @@ def self.name sample_manifest_asset.sample.save sf = described_class.new(value: '', sample_manifest_asset: sample_manifest_asset) sf.supplier_name = bs_supplier_name - sf.update(aliquot: aliquot) + sf.update(aliquot:) aliquot.save expect(sample_manifest_asset.sample.control).to be(false) expect(sample_manifest_asset.sample.control_type).to be_nil @@ -1005,7 +1009,7 @@ def self.name # This section is for the Retention instruction field added as part of the Labware Destruction work describe SequencescapeExcel::SpecialisedField::RetentionInstruction do - let(:user) { create :user } + let(:user) { create(:user) } shared_examples 'a retention instruction labware' do it 'will be invalid if the value is not set' do @@ -1053,23 +1057,23 @@ def self.name end context 'when processing plate wells' do - let(:asset_plate) { create :plate_with_untagged_wells, sample_count: 1 } + let(:asset_plate) { create(:plate_with_untagged_wells, sample_count: 1) } let(:asset) { asset_plate.wells.first } it_behaves_like 'a retention instruction labware' end context 'when processing tubes' do - let(:asset) { create :sample_tube } + let(:asset) { create(:sample_tube) } it_behaves_like 'a retention instruction labware' end context 'when retention instruction is updated (through manifests) for a labware that doesn\'t have retention instructions' do - let(:asset_plate) { create :plate_with_untagged_wells, sample_count: 1 } + let(:asset_plate) { create(:plate_with_untagged_wells, sample_count: 1) } let(:asset) { asset_plate.wells.first } - let(:user) { create :user } + let(:user) { create(:user) } before do custom_metadatum = CustomMetadatum.new diff --git a/spec/sequencescape_excel/validation_spec.rb b/spec/sequencescape_excel/validation_spec.rb index 2aa5248d56..2ea3f491bc 100644 --- a/spec/sequencescape_excel/validation_spec.rb +++ b/spec/sequencescape_excel/validation_spec.rb @@ -14,15 +14,15 @@ it 'is comparable' do # We are explicitly checking that comparable non-identical object show equality # rubocop:disable RSpec/IdenticalEqualityAssertion - expect(described_class.new(options: options)).to eq(described_class.new(options: options)) + expect(described_class.new(options:)).to eq(described_class.new(options:)) # rubocop:enable RSpec/IdenticalEqualityAssertion - expect(described_class.new(options: options.except(:formula1))).not_to eq(described_class.new(options: options)) + expect(described_class.new(options: options.except(:formula1))).not_to eq(described_class.new(options:)) end context 'without range name' do - let(:validation) { described_class.new(options: options) } + let(:validation) { described_class.new(options:) } it 'will have some options' do expect(validation.options).to eq(options) @@ -53,7 +53,7 @@ context 'with a custom formula' do let(:options) { { type: :custom, formula1: 'AND(A1>5,A1<10)' } } - let(:validation) { described_class.new(options: options) } + let(:validation) { described_class.new(options:) } it 'sends and escaped formula to the worksheet' do expect(worksheet).to receive(:add_data_validation).with( @@ -68,7 +68,7 @@ context 'with worksheet' do let(:worksheet) { Axlsx::Package.new.workbook.add_worksheet } let(:range) { build(:range) } - let(:validation) { described_class.new(options: options) } + let(:validation) { described_class.new(options:) } it 'has some options' do expect(validation.options).to eq(options) @@ -84,7 +84,7 @@ it 'is comparable' do validation.update(reference: range.reference, worksheet: worksheet) - other_validation = described_class.new(options: options) + other_validation = described_class.new(options:) other_validation.update(reference: range.reference, worksheet: worksheet) expect(other_validation).to eq(validation) diff --git a/spec/sequencescape_excel/worksheet_spec.rb b/spec/sequencescape_excel/worksheet_spec.rb index 16ba4e6cca..118cb6cf58 100644 --- a/spec/sequencescape_excel/worksheet_spec.rb +++ b/spec/sequencescape_excel/worksheet_spec.rb @@ -24,11 +24,11 @@ def save_file end before do - create :tag_group, adapter_type: (create :adapter_type, name: 'chromium') - create :primer_panel + create(:tag_group, adapter_type: create(:adapter_type, name: 'chromium')) + create(:primer_panel) allow(PlateBarcode).to receive(:create_barcode).and_return(build(:plate_barcode)) - @sample_manifest = create :sample_manifest + @sample_manifest = create(:sample_manifest) sample_manifest.generate end diff --git a/spec/shared_contexts/it_requires_login.rb b/spec/shared_contexts/it_requires_login.rb index fc43ce6c09..16e03881d6 100644 --- a/spec/shared_contexts/it_requires_login.rb +++ b/spec/shared_contexts/it_requires_login.rb @@ -11,14 +11,14 @@ session[:user] = create(:user) if params[:resource].present? resource = params.delete(:resource) - params['id'] = (create resource).id + params['id'] = create(resource).id end if params[:parent].present? parent_resource = params.delete(:parent) - params["#{parent_resource}_id"] = (create parent_resource).id + params["#{parent_resource}_id"] = create(parent_resource).id end begin - get action, params: params + get(action, params:) rescue AbstractController::ActionNotFound flunk "Testing for an unknown action: #{action}" rescue ActiveRecord::RecordNotFound @@ -38,14 +38,14 @@ session[:user] = nil if params[:resource].present? resource = params.delete(:resource) - params['id'] = (create resource).id + params['id'] = create(resource).id end if params[:parent].present? parent_resource = params.delete(:parent) - params["#{parent_resource}_id"] = (create parent_resource).id + params["#{parent_resource}_id"] = create(parent_resource).id end begin - get action, params: params + get(action, params:) rescue AbstractController::ActionNotFound flunk "Testing for an unknown action: #{action}" end diff --git a/spec/shared_contexts/limber_shared_context.rb b/spec/shared_contexts/limber_shared_context.rb index 2d8e4905ee..2427fb9b77 100644 --- a/spec/shared_contexts/limber_shared_context.rb +++ b/spec/shared_contexts/limber_shared_context.rb @@ -10,25 +10,25 @@ # The input plate represents the plate going into the pipeline # from which the requests will be made. - let(:input_plate) { create :input_plate, well_count: tested_wells, well_factory: :tagged_well } - let(:library_request_type) { create :library_request_type } - let(:multiplex_request_type) { create :multiplex_request_type } + let(:input_plate) { create(:input_plate, well_count: tested_wells, well_factory: :tagged_well) } + let(:library_request_type) { create(:library_request_type) } + let(:multiplex_request_type) { create(:multiplex_request_type) } let(:submission_request_types) { [library_request_type, multiplex_request_type] } # The target submission represents the submission we're about to pass requests for let(:target_submission) do - create :library_submission, assets: input_plate.wells, request_types: submission_request_types + create(:library_submission, assets: input_plate.wells, request_types: submission_request_types) end let(:order) { target_submission.orders.first } # The decoy submission represents a submission which we don't care about let(:decoy_submission) do - create :library_submission, assets: input_plate.wells, request_types: submission_request_types + create(:library_submission, assets: input_plate.wells, request_types: submission_request_types) end # The target plate is the downstream plate we are going to be passing. let(:target_plate) do - create :target_plate, parent: input_plate, well_count: tested_wells, submission: target_submission + create(:target_plate, parent: input_plate, well_count: tested_wells, submission: target_submission) end # And now we have a few helpers to make the tests more readable @@ -38,18 +38,22 @@ let(:build_library_requests) do input_plate.wells.each do |well| - create_list :library_request, - requests_per_well, - request_type: library_request_type, - asset: well, - submission: target_submission, - state: library_state, - order: order - create :library_request, - request_type: library_request_type, - asset: well, - submission: decoy_submission, - state: library_state + create_list( + :library_request, + requests_per_well, + request_type: library_request_type, + asset: well, + submission: target_submission, + state: library_state, + order: order + ) + create( + :library_request, + request_type: library_request_type, + asset: well, + submission: decoy_submission, + state: library_state + ) end end @@ -59,8 +63,8 @@ build_library_requests submission_request_types[1..].each do |downstream_type| input_plate.wells.count.times do - create_list :multiplex_request, requests_per_well, request_type: downstream_type, submission: target_submission - create :multiplex_request, request_type: downstream_type, submission: decoy_submission + create_list(:multiplex_request, requests_per_well, request_type: downstream_type, submission: target_submission) + create(:multiplex_request, request_type: downstream_type, submission: decoy_submission) end end end diff --git a/spec/spec_helper.rb b/spec/spec_helper.rb index 813b1f0804..39210c9b0e 100644 --- a/spec/spec_helper.rb +++ b/spec/spec_helper.rb @@ -88,7 +88,7 @@ DatabaseCleaner.clean_with(:truncation) end - config.around(:each) { |example| DatabaseCleaner.cleaning { example.run } } + config.around { |example| DatabaseCleaner.cleaning { example.run } } # rspec-expectations config goes here. You can use an alternate # assertion/expectation library such as wrong or the stdlib/minitest diff --git a/spec/support/api_v2_helper.rb b/spec/support/api_v2_helper.rb index e148ccd6e3..14aeb5a776 100644 --- a/spec/support/api_v2_helper.rb +++ b/spec/support/api_v2_helper.rb @@ -5,7 +5,7 @@ module ApiV2Helper def api_get(path, headers: {}) headers.merge!(DEFAULT_HEADERS) - get(path, headers: headers) + get(path, headers:) end def api_patch(path, payload, headers: {}) diff --git a/spec/support/api_v2_resource_matchers.rb b/spec/support/api_v2_resource_matchers.rb new file mode 100644 index 0000000000..cb081e288e --- /dev/null +++ b/spec/support/api_v2_resource_matchers.rb @@ -0,0 +1,39 @@ +# frozen_string_literal: true + +module ApiV2Matchers + RSpec::Matchers.define :have_readonly_attribute do |attribute| + description { "have read-only attribute `#{attribute}`" } + + failure_message { "expected #{resource.class.name.demodulize} to #{description}" } + failure_message_when_negated { "expected #{resource.class.name.demodulize} not to #{description}" } + + match do |resource| + expect(resource).to have_attribute attribute + expect(resource).not_to have_updatable_field attribute + end + end + + RSpec::Matchers.define :have_readwrite_attribute do |attribute| + description { "have read-write attribute `#{attribute}`" } + + failure_message { "expected #{resource.class.name.demodulize} to #{description}" } + failure_message_when_negated { "expected #{resource.class.name.demodulize} not to #{description}" } + + match do |resource| + expect(resource).to have_attribute attribute + expect(resource).to have_updatable_field attribute + end + end + + RSpec::Matchers.define :have_writeonly_attribute do |attribute| + description { "have write-only attribute `#{attribute}`" } + + failure_message { "expected #{resource.class.name.demodulize} to #{description}" } + failure_message_when_negated { "expected #{resource.class.name.demodulize} not to #{description}" } + + match do |resource| + expect(resource).not_to have_attribute attribute + expect(resource).to have_updatable_field attribute + end + end +end diff --git a/spec/tasks/support/remove_duplicate_asset_links_spec.rb b/spec/tasks/support/remove_duplicate_asset_links_spec.rb new file mode 100644 index 0000000000..b34eebdc98 --- /dev/null +++ b/spec/tasks/support/remove_duplicate_asset_links_spec.rb @@ -0,0 +1,51 @@ +# frozen_string_literal: true + +require 'rails_helper' + +# rubocop:disable RSpec/ExampleLength, RSpec/MultipleExpectations,RSpec/MultipleMemoizedHelpers +RSpec.describe 'support:remove_duplicate_asset_links', type: :task do + let(:clear_tasks) { Rake.application.clear } + let(:load_tasks) { Rails.application.load_tasks } + let(:task_reenable) { Rake::Task[self.class.top_level_description].reenable } + let(:task_invoke) { Rake::Task[self.class.top_level_description].invoke(csv_file_path) } + let(:csv_file_path) { 'tmp/deleted_asset_links.csv' } + let(:links) { create_list(:asset_link, 5) } + let(:duplicate_links) do + links.map do |link| + duplicate = AssetLink.new(ancestor: link.ancestor, descendant: link.descendant, created_at: 1.day.ago) + duplicate.save!(validate: false) # Needs to be saved without validation + duplicate + end + end + + before do + clear_tasks + load_tasks + task_reenable + links + duplicate_links + end + + after { File.delete(csv_file_path) if File.exist?(csv_file_path) } + + it 'removes all duplicate links except the most recently created ones' do + expect(AssetLink.count).to eq(links.size + duplicate_links.size) + task_invoke + expect(AssetLink.count).to eq(links.size) # most recent links should be kept + expect(AssetLink.exists?(links.first.id)).to be true + expect(AssetLink.exists?(duplicate_links.first.id)).to be false + end + + it 'exports the removed duplicates to a CSV file' do + task_invoke + expect(File.exist?(csv_file_path)).to be true + csv = CSV.read(Rails.root.join(csv_file_path)) + expect(csv.size).to eq(duplicate_links.size + 1) # With header. + expect(csv.first).to eq(AssetLink.column_names) + (1..duplicate_links.size).each do |i| + expected_row = duplicate_links[i - 1].attributes.values.map { |value| value&.to_s } + expect(csv[i]).to eq(expected_row) + end + end +end +# rubocop:enable RSpec/ExampleLength, RSpec/MultipleExpectations,RSpec/MultipleMemoizedHelpers diff --git a/spec/uat_actions/generate_plate_concentrations_spec.rb b/spec/uat_actions/generate_plate_concentrations_spec.rb index f090c21fef..0c15ece3cb 100644 --- a/spec/uat_actions/generate_plate_concentrations_spec.rb +++ b/spec/uat_actions/generate_plate_concentrations_spec.rb @@ -4,7 +4,7 @@ describe UatActions::GeneratePlateConcentrations do context 'with valid options' do - let(:plate) { create :plate_with_untagged_wells, sample_count: 3 } + let(:plate) { create(:plate_with_untagged_wells, sample_count: 3) } let(:uat_action) { described_class.new(parameters) } let(:report) do # A report is a hash of key value pairs which get returned to the user. diff --git a/spec/uat_actions/generate_project_spec.rb b/spec/uat_actions/generate_project_spec.rb index 8d99d25a59..ba7a889e4e 100644 --- a/spec/uat_actions/generate_project_spec.rb +++ b/spec/uat_actions/generate_project_spec.rb @@ -7,7 +7,7 @@ let(:uat_action) { described_class.new(parameters) } let(:project_name) { 'Test Project' } let(:project_cost_code) { '1234' } - let(:parameters) { { project_name: project_name, project_cost_code: project_cost_code } } + let(:parameters) { { project_name:, project_cost_code: } } describe '#perform' do context 'when generating a project' do diff --git a/spec/uat_actions/generate_qc_results_spec.rb b/spec/uat_actions/generate_qc_results_spec.rb index ce90f2dd33..f2780011b7 100644 --- a/spec/uat_actions/generate_qc_results_spec.rb +++ b/spec/uat_actions/generate_qc_results_spec.rb @@ -4,8 +4,8 @@ describe UatActions::GenerateQcResults do context 'with valid options' do - let(:plate) { create :plate_with_untagged_wells, sample_count: 3 } - let(:tube) { create :sample_tube, barcode: '1' } + let(:plate) { create(:plate_with_untagged_wells, sample_count: 3) } + let(:tube) { create(:sample_tube, barcode: '1') } let(:uat_action) { described_class.new(parameters) } let(:report) do diff --git a/spec/uat_actions/generate_sample_manifest_spec.rb b/spec/uat_actions/generate_sample_manifest_spec.rb index df8551c09d..44f5be3144 100644 --- a/spec/uat_actions/generate_sample_manifest_spec.rb +++ b/spec/uat_actions/generate_sample_manifest_spec.rb @@ -68,14 +68,7 @@ end describe '#create_sample_manifest' do - let(:manifest) do - create :sample_manifest, - study: study, - supplier: supplier, - count: count, - asset_type: asset_type, - purpose: purpose - end + let(:manifest) { create(:sample_manifest, study:, supplier:, count:, asset_type:, purpose:) } it 'sets the created sample manifest' do allow(SampleManifest).to receive(:create!).and_return(manifest) @@ -85,14 +78,7 @@ end describe '#generate_manifest' do - let(:manifest) do - create :sample_manifest, - study: study, - supplier: supplier, - count: count, - asset_type: asset_type, - purpose: purpose - end + let(:manifest) { create(:sample_manifest, study:, supplier:, count:, asset_type:, purpose:) } it 'create tubes(s)' do expect { uat_action.generate_manifest(manifest) }.to change(SampleTube, :count).by(count).and change { diff --git a/spec/uat_actions/generate_spiked_buffer_tube_spec.rb b/spec/uat_actions/generate_spiked_buffer_tube_spec.rb index 72ac2c9a85..829cb2a8c9 100644 --- a/spec/uat_actions/generate_spiked_buffer_tube_spec.rb +++ b/spec/uat_actions/generate_spiked_buffer_tube_spec.rb @@ -4,7 +4,7 @@ describe UatActions::GenerateSpikedBufferTube do context 'with valid options' do - before { create :study, name: PhiX.configuration[:default_study_option] } + before { create(:study, name: PhiX.configuration[:default_study_option]) } let(:uat_action) { described_class.new(parameters) } diff --git a/spec/uat_actions/generate_study_spec.rb b/spec/uat_actions/generate_study_spec.rb index 9f4e302fa9..2f287b1843 100644 --- a/spec/uat_actions/generate_study_spec.rb +++ b/spec/uat_actions/generate_study_spec.rb @@ -6,7 +6,7 @@ context 'with valid options' do let(:uat_action) { described_class.new(parameters) } let(:study_name) { 'Test Study' } - let(:parameters) { { study_name: study_name } } + let(:parameters) { { study_name: } } describe '#perform' do context 'when generating a study' do diff --git a/spec/uat_actions/generate_tag_layout_template_spec.rb b/spec/uat_actions/generate_tag_layout_template_spec.rb index 0fddbe859c..bb5ac24462 100644 --- a/spec/uat_actions/generate_tag_layout_template_spec.rb +++ b/spec/uat_actions/generate_tag_layout_template_spec.rb @@ -5,8 +5,8 @@ describe UatActions::GenerateTagLayoutTemplate do context 'with valid options' do let(:tag_count) { 96 } - let(:tag_group) { create :tag_group, tag_count: tag_count } - let(:tag2_group) { create :tag_group, tag_count: tag_count } + let(:tag_group) { create(:tag_group, tag_count:) } + let(:tag2_group) { create(:tag_group, tag_count:) } let(:parameters) do { diff --git a/spec/uat_actions/plate_information_spec.rb b/spec/uat_actions/plate_information_spec.rb index df5e875e17..8cf2656bfd 100644 --- a/spec/uat_actions/plate_information_spec.rb +++ b/spec/uat_actions/plate_information_spec.rb @@ -5,7 +5,7 @@ describe UatActions::PlateInformation do context 'when the plate has aliquots' do let(:plate_barcode) { 'SQPD-1' } - let(:parameters) { { plate_barcode: plate_barcode } } + let(:parameters) { { plate_barcode: } } let(:uat_action) { described_class.new(parameters) } let(:report) do # A report is a hash of key value pairs which get returned to the user. @@ -13,7 +13,7 @@ { plate_barcode: plate_barcode, wells_with_aliquots: 'A1, B1, C1', wells_with_active_requests_as_source: '' } end - before { create :plate_with_untagged_wells, sample_count: 3, barcode: plate_barcode } + before { create(:plate_with_untagged_wells, sample_count: 3, barcode: plate_barcode) } it 'can be performed' do expect(uat_action.perform).to be true @@ -23,7 +23,7 @@ context 'when the plate is without aliquots' do let(:plate_barcode) { 'SQPD-2' } - let(:parameters) { { plate_barcode: plate_barcode } } + let(:parameters) { { plate_barcode: } } let(:uat_action) { described_class.new(parameters) } let(:report) do # A report is a hash of key value pairs which get returned to the user. @@ -31,7 +31,7 @@ { plate_barcode: plate_barcode, wells_with_aliquots: '', wells_with_active_requests_as_source: '' } end - before { create :plate_with_empty_wells, well_count: 3, barcode: plate_barcode } + before { create(:plate_with_empty_wells, well_count: 3, barcode: plate_barcode) } it 'can be performed' do expect(uat_action.perform).to be true @@ -58,10 +58,10 @@ # We expect to return the wells that have been submitted (have active requests as source) context 'when the plate has a partial submission' do let(:plate_barcode) { 'SQPD-3' } - let(:parameters) { { plate_barcode: plate_barcode } } + let(:parameters) { { plate_barcode: } } let(:uat_action) { described_class.new(parameters) } - let(:submission) { create :submission } - let(:request_type) { create :library_creation_request_type } + let(:submission) { create(:submission) } + let(:request_type) { create(:library_creation_request_type) } let(:report) do { plate_barcode: plate_barcode, @@ -71,24 +71,28 @@ end before do - plate = create :plate_with_untagged_wells, sample_count: 3, barcode: plate_barcode + plate = create(:plate_with_untagged_wells, sample_count: 3, barcode: plate_barcode) plate_wells = plate.wells.with_contents req1 = - create :library_creation_request, - asset: plate_wells.first, - submission: submission, - request_type: request_type, - state: 'started' + create( + :library_creation_request, + asset: plate_wells.first, + submission: submission, + request_type: request_type, + state: 'started' + ) plate_wells.first.requests_as_source << req1 req2 = - create :library_creation_request, - asset: plate_wells.last, - submission: submission, - request_type: request_type, - state: 'started' + create( + :library_creation_request, + asset: plate_wells.last, + submission: submission, + request_type: request_type, + state: 'started' + ) plate_wells.last.requests_as_source << req2 end @@ -102,33 +106,37 @@ # i.e. only want wells with ACTIVE requests as source so this should not return any wells context 'when the plate has a closed submission' do let(:plate_barcode) { 'SQPD-4' } - let(:parameters) { { plate_barcode: plate_barcode } } + let(:parameters) { { plate_barcode: } } let(:uat_action) { described_class.new(parameters) } - let(:submission) { create :submission } - let(:request_type) { create :library_creation_request_type } + let(:submission) { create(:submission) } + let(:request_type) { create(:library_creation_request_type) } let(:report) do { plate_barcode: plate_barcode, wells_with_aliquots: 'A1, B1, C1', wells_with_active_requests_as_source: '' } end before do - plate = create :plate_with_untagged_wells, sample_count: 3, barcode: plate_barcode + plate = create(:plate_with_untagged_wells, sample_count: 3, barcode: plate_barcode) plate_wells = plate.wells.with_contents req1 = - create :library_creation_request, - asset: plate_wells.first, - submission: submission, - request_type: request_type, - state: 'passed' + create( + :library_creation_request, + asset: plate_wells.first, + submission: submission, + request_type: request_type, + state: 'passed' + ) plate_wells.first.requests_as_source << req1 req2 = - create :library_creation_request, - asset: plate_wells.last, - submission: submission, - request_type: request_type, - state: 'passed' + create( + :library_creation_request, + asset: plate_wells.last, + submission: submission, + request_type: request_type, + state: 'passed' + ) plate_wells.last.requests_as_source << req2 end @@ -142,11 +150,11 @@ # subsets of wells) - we expect to only return the wells with the new (active) submission context 'when the plate has both active and closed submissions' do let(:plate_barcode) { 'SQPD-4' } - let(:parameters) { { plate_barcode: plate_barcode } } + let(:parameters) { { plate_barcode: } } let(:uat_action) { described_class.new(parameters) } - let(:submission) { create :submission } - let(:submission2) { create :submission } - let(:request_type) { create :library_creation_request_type } + let(:submission) { create(:submission) } + let(:submission2) { create(:submission) } + let(:request_type) { create(:library_creation_request_type) } let(:report) do { plate_barcode: plate_barcode, @@ -156,48 +164,58 @@ end before do - plate = create :plate_with_untagged_wells, sample_count: 3, barcode: plate_barcode + plate = create(:plate_with_untagged_wells, sample_count: 3, barcode: plate_barcode) plate_wells = plate.wells.with_contents req1 = - create :library_creation_request, - asset: plate_wells.first, - submission: submission, - request_type: request_type, - state: 'passed' + create( + :library_creation_request, + asset: plate_wells.first, + submission: submission, + request_type: request_type, + state: 'passed' + ) plate_wells.first.requests_as_source << req1 req2 = - create :library_creation_request, - asset: plate_wells.second, - submission: submission, - request_type: request_type, - state: 'passed' + create( + :library_creation_request, + asset: plate_wells.second, + submission: submission, + request_type: request_type, + state: 'passed' + ) plate_wells.second.requests_as_source << req2 req3 = - create :library_creation_request, - asset: plate_wells.last, - submission: submission, - request_type: request_type, - state: 'passed' + create( + :library_creation_request, + asset: plate_wells.last, + submission: submission, + request_type: request_type, + state: 'passed' + ) plate_wells.last.requests_as_source << req3 req4 = - create :library_creation_request, - asset: plate_wells.first, - submission: submission2, - request_type: request_type, - state: 'started' + create( + :library_creation_request, + asset: plate_wells.first, + submission: submission2, + request_type: request_type, + state: 'started' + ) plate_wells.first.requests_as_source << req4 req5 = - create :library_creation_request, - asset: plate_wells.last, - submission: submission2, - request_type: request_type, - state: 'started' + create( + :library_creation_request, + asset: plate_wells.last, + submission: submission2, + request_type: request_type, + state: 'started' + ) plate_wells.last.requests_as_source << req5 end diff --git a/spec/uat_actions/test_submission_spec.rb b/spec/uat_actions/test_submission_spec.rb index 43311460fe..5230308d32 100644 --- a/spec/uat_actions/test_submission_spec.rb +++ b/spec/uat_actions/test_submission_spec.rb @@ -6,8 +6,8 @@ context 'valid options' do before { expect(PlateBarcode).to receive(:create_barcode).and_return(first_plate_barcode) } - let(:submission_template) { create :limber_wgs_submission_template } - let(:primer_panel) { create :primer_panel } + let(:submission_template) { create(:limber_wgs_submission_template) } + let(:primer_panel) { create(:primer_panel) } let(:parameters) { { submission_template_name: submission_template.name } } let(:uat_action) { described_class.new(parameters) } let(:first_plate_barcode) { build(:plate_barcode) } diff --git a/spec/uat_actions/tube_submission_spec.rb b/spec/uat_actions/tube_submission_spec.rb new file mode 100644 index 0000000000..b66d74b390 --- /dev/null +++ b/spec/uat_actions/tube_submission_spec.rb @@ -0,0 +1,81 @@ +# frozen_string_literal: true + +require 'rails_helper' + +describe UatActions::TubeSubmission do + context 'with valid options' do + let(:tube) { create(:sample_tube, purpose: create(:sample_tube_purpose)) } + let(:tube_barcode) { tube.barcodes.last.barcode } + let(:submission_template) { create(:pbmc_pooling_submission_template) } + let(:parameters) { { submission_template_name: submission_template.name, tube_barcodes: tube_barcode } } + let(:uat_action) { described_class.new(parameters) } + let(:report) do + # A report is a hash of key value pairs which get returned to the user. + # It should include information such as barcodes and identifiers + { 'tube_barcodes' => [tube_barcode] } + end + + it 'can be performed' do + expect(uat_action.perform).to be true + expect(uat_action.report['tube_barcodes']).to eq report['tube_barcodes'] + expect(uat_action.report['submission_id']).to be_a Integer + end + + context 'with optional library type supplied' do + let(:parameters) do + { + submission_template_name: submission_template.name, + tube_barcodes: tube_barcode, + library_type_name: 'Standard' + } + end + + it 'can be performed' do + expect(uat_action.perform).to be true + expect(uat_action.report['tube_barcodes']).to eq report['tube_barcodes'] + expect(uat_action.report['submission_id']).to be_a Integer + expect(uat_action.report['library_type']).to eq 'Standard' + end + end + + context 'with optional number of samples per pool supplied' do + let(:num_samples) { 15 } + let(:parameters) do + { + submission_template_name: submission_template.name, + tube_barcodes: tube_barcode, + number_of_samples_per_pool: num_samples + } + end + + it 'can be performed' do + expect(uat_action.perform).to be true + expect(uat_action.report['tube_barcodes']).to eq report['tube_barcodes'] + expect(uat_action.report['submission_id']).to be_a Integer + expect(uat_action.report['number_of_samples_per_pool']).to eq num_samples + end + end + + context 'with optional cells per chip well supplied' do + let(:num_cells) { 20_000 } + let(:parameters) do + { + submission_template_name: submission_template.name, + tube_barcodes: tube_barcode, + cells_per_chip_well: num_cells + } + end + + it 'can be performed' do + expect(uat_action.perform).to be true + expect(uat_action.report['tube_barcodes']).to eq report['tube_barcodes'] + expect(uat_action.report['submission_id']).to be_a Integer + expect(uat_action.report['cells_per_chip_well']).to eq num_cells + end + end + end + + it 'returns a default' do + expect(described_class.default).to be_a described_class + end +end diff --git a/spec/validators/novaseqx_pe_validator_spec.rb b/spec/validators/novaseqx_pe_validator_spec.rb index e0c52c5c17..6178f22494 100644 --- a/spec/validators/novaseqx_pe_validator_spec.rb +++ b/spec/validators/novaseqx_pe_validator_spec.rb @@ -5,7 +5,7 @@ describe NovaseqxPeValidator do describe '#validate' do context 'with batch_size_for_flowcell_type validations' do - let(:record) { create :batch, request_count: 2 } + let(:record) { create(:batch, request_count: 2) } it 'returns true if no requests are selected' do record.requests = [] @@ -35,7 +35,7 @@ ].each do |batch_data| it "returns #{batch_data[:result].nil? ? 'nil' : batch_data[:result]} if the flowcell_type is #{batch_data[:flowcell_type]} and the request count is #{batch_data[:request_count]}" do - record = create :batch, request_count: batch_data[:request_count] + record = create(:batch, request_count: batch_data[:request_count]) record.requests.each do |request| request.request_metadata.requested_flowcell_type = batch_data[:flowcell_type] end diff --git a/spec/views/labware/retention_instruction_spec.rb b/spec/views/labware/retention_instruction_spec.rb index 5f1d57cf39..ba58f0f151 100644 --- a/spec/views/labware/retention_instruction_spec.rb +++ b/spec/views/labware/retention_instruction_spec.rb @@ -5,7 +5,7 @@ RSpec.describe 'labware/retention_instruction.html.erb' do include AuthenticatedSystem include RetentionInstructionHelper - let(:user) { create :user } + let(:user) { create(:user) } shared_examples 'displaying retention instruction' do it 'displays the retention instruction' do @@ -37,14 +37,14 @@ context 'when rendering an existing retention instruction - plate' do let(:current_user) { user } - let(:asset) { create :plate_with_3_wells, retention_instruction: :destroy_after_2_years } + let(:asset) { create(:plate_with_3_wells, retention_instruction: :destroy_after_2_years) } it_behaves_like 'displaying retention instruction' end context 'when rendering an existing retention instruction - tube' do let(:current_user) { user } - let(:asset) { create :tube, retention_instruction: :destroy_after_2_years } + let(:asset) { create(:tube, retention_instruction: :destroy_after_2_years) } it_behaves_like 'displaying retention instruction' end diff --git a/spec/views/labware/show_chromium_chip_spec.rb b/spec/views/labware/show_chromium_chip_spec.rb index f9c7fe11e3..c4dc02ee57 100644 --- a/spec/views/labware/show_chromium_chip_spec.rb +++ b/spec/views/labware/show_chromium_chip_spec.rb @@ -4,7 +4,7 @@ RSpec.describe 'labware/show.html.erb' do include AuthenticatedSystem - let(:user) { create :user } + let(:user) { create(:user) } context 'when rendering a Chromium Chip 16-well plate' do # We have a plate with a purpose that has an asset_shape of Shape4x1 @@ -13,8 +13,8 @@ let(:current_user) { user } let(:purpose_name) { 'chromium-chip-purpose' } - let(:purpose) { create :shape4x1_purpose, name: purpose_name } # AssetShape Shape4x1, size 16 - let(:plate) { create :child_plate, well_factory: :passed_well, purpose: purpose, size: 16, sample_count: 16 } + let(:purpose) { create(:shape4x1_purpose, name: purpose_name) } # AssetShape Shape4x1, size 16 + let(:plate) { create(:child_plate, well_factory: :passed_well, purpose: purpose, size: 16, sample_count: 16) } let(:doc) { Nokogiri.HTML(rendered) } before do diff --git a/spec/views/labware/show_html_erb_spec.rb b/spec/views/labware/show_html_erb_spec.rb index 578e5e17e6..cda9966ed2 100644 --- a/spec/views/labware/show_html_erb_spec.rb +++ b/spec/views/labware/show_html_erb_spec.rb @@ -4,7 +4,7 @@ RSpec.describe 'labware/show.html.erb' do # rubocop:todo RSpec/DescribeClass include AuthenticatedSystem - let(:user) { create :user } + let(:user) { create(:user) } shared_examples 'retention instruction' do it 'displays retention key instruction in asset summary' do @@ -20,7 +20,7 @@ context 'when rendering a plate' do let(:current_user) { user } - let(:plate) { create :plate_with_3_wells } + let(:plate) { create(:plate_with_3_wells) } before do assign(:asset, plate) # sets @widget = Widget.new in the view template @@ -64,11 +64,11 @@ context 'when rendering a tube rack' do let(:current_user) { user } - let(:rack_barcode) { create :barcode } - let(:tube_rack) { create :tube_rack, barcode: rack_barcode } + let(:rack_barcode) { create(:barcode) } + let(:tube_rack) { create(:tube_rack, barcode: rack_barcode) } let(:locations) { %w[A01 B01 C01] } - let(:barcodes) { Array.new(num_tubes) { create :fluidx } } + let(:barcodes) { Array.new(num_tubes) { create(:fluidx) } } let!(:tubes) do Array.new(num_tubes) do |i| create(:sample_tube, :in_a_rack, tube_rack: tube_rack, coordinate: locations[i], barcodes: [barcodes[i]]) @@ -102,8 +102,8 @@ context 'when rendering a tube' do let(:current_user) { user } - let(:tube_barcode) { create :fluidx } - let(:tube) { create :tube, barcodes: [tube_barcode] } + let(:tube_barcode) { create(:fluidx) } + let(:tube) { create(:tube, barcodes: [tube_barcode]) } before do assign(:asset, tube) # sets @widget = Widget.new in the view template @@ -111,13 +111,13 @@ end context 'when the tube is inside a rack' do - before { tube.update(racked_tube: racked_tube) } + before { tube.update(racked_tube:) } let(:coordinate) { 'A1' } - let(:racked_tube) { build :racked_tube, tube_rack: tube_rack, coordinate: coordinate } + let(:racked_tube) { build(:racked_tube, tube_rack:, coordinate:) } - let(:rack_barcode) { create :barcode } - let(:tube_rack) { create :tube_rack, barcodes: [rack_barcode] } + let(:rack_barcode) { create(:barcode) } + let(:tube_rack) { create(:tube_rack, barcodes: [rack_barcode]) } it 'renders a tube description label' do render diff --git a/spec/views/report_fails/index_html_erb_spec.rb b/spec/views/report_fails/index_html_erb_spec.rb index 916c913c7f..b9b82c16b4 100644 --- a/spec/views/report_fails/index_html_erb_spec.rb +++ b/spec/views/report_fails/index_html_erb_spec.rb @@ -4,7 +4,7 @@ RSpec.describe 'report_fails/index.html.erb' do include AuthenticatedSystem - let(:user) { create :user } + let(:user) { create(:user) } context 'when rendering the index' do let(:current_user) { user } diff --git a/spec/views/samples/edit_html_erb_spec.rb b/spec/views/samples/edit_html_erb_spec.rb index addee9c510..cf5d3aba71 100644 --- a/spec/views/samples/edit_html_erb_spec.rb +++ b/spec/views/samples/edit_html_erb_spec.rb @@ -5,11 +5,11 @@ RSpec.describe 'samples/edit.html.erb' do include AuthenticatedSystem include RSpecHtmlMatchers - let(:user) { create :user } + let(:user) { create(:user) } context 'when rendering the edit view' do let(:current_user) { user } - let(:sample) { create :sample } + let(:sample) { create(:sample) } let(:time) { DateTime.now } context 'when the sample has consent withdrawn' do diff --git a/spec/views/samples/index_html_erb_spec.rb b/spec/views/samples/index_html_erb_spec.rb index 3f3bdef2aa..ccee843d85 100644 --- a/spec/views/samples/index_html_erb_spec.rb +++ b/spec/views/samples/index_html_erb_spec.rb @@ -4,11 +4,11 @@ RSpec.describe 'samples/index.html.erb' do include AuthenticatedSystem - let(:user) { create :user } + let(:user) { create(:user) } context 'when rendering the index view' do let(:current_user) { user } - let(:samples) { create_list :sample, 4 } + let(:samples) { create_list(:sample, 4) } let(:time) { DateTime.now.utc } let(:time2) { DateTime.now.utc + 5 } diff --git a/spec/views/samples/show_html_erb_spec.rb b/spec/views/samples/show_html_erb_spec.rb index dba8c7e3d1..e89071b61f 100644 --- a/spec/views/samples/show_html_erb_spec.rb +++ b/spec/views/samples/show_html_erb_spec.rb @@ -4,11 +4,11 @@ RSpec.describe 'samples/show.html.erb' do include AuthenticatedSystem - let(:user) { create :user } + let(:user) { create(:user) } context 'when rendering a sample' do let(:current_user) { user } - let(:sample) { create :sample } + let(:sample) { create(:sample) } let(:time) { DateTime.now.utc } context 'when the user has withdrawn consent' do diff --git a/spec/views/tube_rack_summaries/show_html_erb_spec.rb b/spec/views/tube_rack_summaries/show_html_erb_spec.rb index d631bc8875..4f9b07a53e 100644 --- a/spec/views/tube_rack_summaries/show_html_erb_spec.rb +++ b/spec/views/tube_rack_summaries/show_html_erb_spec.rb @@ -4,15 +4,15 @@ RSpec.describe 'tube_rack_summaries/show.html.erb' do include AuthenticatedSystem - let(:user) { create :user } + let(:user) { create(:user) } context 'when rendering a tube rack summary' do let(:current_user) { user } - let(:rack_barcode) { create :barcode } - let(:tube_rack) { create :tube_rack, barcode: rack_barcode } + let(:rack_barcode) { create(:barcode) } + let(:tube_rack) { create(:tube_rack, barcode: rack_barcode) } let(:locations) { %w[A01 B01 C01] } - let(:barcodes) { Array.new(num_tubes) { create :fluidx } } + let(:barcodes) { Array.new(num_tubes) { create(:fluidx) } } before do Array.new(num_tubes) do |i| diff --git a/test/controllers/admin_controller_test.rb b/test/controllers/admin_controller_test.rb index c7029694b5..4735d1f243 100644 --- a/test/controllers/admin_controller_test.rb +++ b/test/controllers/admin_controller_test.rb @@ -12,7 +12,7 @@ class AdminControllerTest < ActionController::TestCase should_require_login context 'admin frontpage' do - setup { session[:user] = @user = create :admin } + setup { session[:user] = @user = create(:admin) } context '#index' do setup { get :index } diff --git a/test/controllers/admin_programs_controller_test.rb b/test/controllers/admin_programs_controller_test.rb index 49f1014260..fcae80af66 100644 --- a/test/controllers/admin_programs_controller_test.rb +++ b/test/controllers/admin_programs_controller_test.rb @@ -8,13 +8,13 @@ class ProgramsControllerTest < ActionController::TestCase setup do @controller = Admin::ProgramsController.new @request = ActionController::TestRequest.create(@controller) - session[:user] = @user = create :admin + session[:user] = @user = create(:admin) end should_require_login context '#create' do - setup { FactoryBot.create :program, name: 'My unique name of program' } + setup { FactoryBot.create(:program, name: 'My unique name of program') } should 'create a new program' do num = Program.count @@ -32,7 +32,7 @@ class ProgramsControllerTest < ActionController::TestCase end context '#edit' do - setup { @program = FactoryBot.create :program, name: 'My program name' } + setup { @program = FactoryBot.create(:program, name: 'My program name') } should 'edit the name of the new program' do post :update, params: { id: @program.id, program: { name: 'A new name for the program' } } @@ -44,7 +44,7 @@ class ProgramsControllerTest < ActionController::TestCase end context '#show' do - setup { @program = create :program } + setup { @program = create(:program) } should 'display existing programs' do get :show, params: { id: @program.id } diff --git a/test/controllers/admin_projects_controller_test.rb b/test/controllers/admin_projects_controller_test.rb index 0c69f3bb32..5281098d9b 100644 --- a/test/controllers/admin_projects_controller_test.rb +++ b/test/controllers/admin_projects_controller_test.rb @@ -17,12 +17,12 @@ class ProjectsControllerTest < ActionController::TestCase context 'management UI' do setup do - @user = create :admin, email: 'project.owner@example.com' - @project = create :project, approved: false - role = FactoryBot.create :owner_role, authorizable: @project + @user = create(:admin, email: 'project.owner@example.com') + @project = create(:project, approved: false) + role = FactoryBot.create(:owner_role, authorizable: @project) role.users << @user - @request_type = FactoryBot.create :request_type - @other_request_type = FactoryBot.create :request_type + @request_type = FactoryBot.create(:request_type) + @other_request_type = FactoryBot.create(:request_type) session[:user] = @user.id @emails = ActionMailer::Base.deliveries @emails.clear diff --git a/test/controllers/admin_roles_controller_test.rb b/test/controllers/admin_roles_controller_test.rb index adcd7bda24..6e413d7406 100644 --- a/test/controllers/admin_roles_controller_test.rb +++ b/test/controllers/admin_roles_controller_test.rb @@ -13,7 +13,7 @@ class RolesControllerTest < ActionController::TestCase should_require_login context 'with user' do - setup { session[:user] = @user = create :admin } + setup { session[:user] = @user = create(:admin) } resource_test( 'role', diff --git a/test/controllers/admin_studies_controller_test.rb b/test/controllers/admin_studies_controller_test.rb index 7996d83f5f..db80564090 100644 --- a/test/controllers/admin_studies_controller_test.rb +++ b/test/controllers/admin_studies_controller_test.rb @@ -14,9 +14,9 @@ class StudiesControllerTest < ActionController::TestCase context 'management UI' do setup do - @user = FactoryBot.create :admin - @study = FactoryBot.create :study - @request_type = FactoryBot.create :request_type + @user = FactoryBot.create(:admin) + @study = FactoryBot.create(:study) + @request_type = FactoryBot.create(:request_type) session[:user] = @user.id @emails = ActionMailer::Base.deliveries @emails.clear @@ -51,7 +51,7 @@ class StudiesControllerTest < ActionController::TestCase end context 'with a data_access_coordinator role' do - setup { @user.roles << (create :data_access_coordinator_role) } + setup { @user.roles << (create(:data_access_coordinator_role)) } should "change 'ethically_approved'" do Rails.logger.info '******** First Request' diff --git a/test/controllers/admin_users_controller_test.rb b/test/controllers/admin_users_controller_test.rb index 49e279fb6f..19e3835461 100644 --- a/test/controllers/admin_users_controller_test.rb +++ b/test/controllers/admin_users_controller_test.rb @@ -32,13 +32,13 @@ class UsersControllerTest < ActionController::TestCase context '#filter' do setup do - @user = FactoryBot.create :user - @admin = FactoryBot.create :admin + @user = FactoryBot.create(:user) + @admin = FactoryBot.create(:admin) session[:user] = @admin - @user_to_find = FactoryBot.create :user, first_name: 'Some', last_name: 'Body', login: 'sb1' - @another_user = FactoryBot.create :user, first_name: 'No', last_name: 'One', login: 'no1' + @user_to_find = FactoryBot.create(:user, first_name: 'Some', last_name: 'Body', login: 'sb1') + @another_user = FactoryBot.create(:user, first_name: 'No', last_name: 'One', login: 'no1') end should 'find a user based on name' do diff --git a/test/controllers/api/submissions_controller.rb b/test/controllers/api/submissions_controller.rb index bed1cef749..68715f175d 100644 --- a/test/controllers/api/submissions_controller.rb +++ b/test/controllers/api/submissions_controller.rb @@ -8,7 +8,7 @@ class SubmissionsControllerTest < ActionController::TestCase setup do @controller = Api::SubmissionsController.new @request = ActionController::TestRequest.create(@controller) - @user = FactoryBot.create :user + @user = FactoryBot.create(:user) @controller.stubs(:logged_in?).returns(@user) session[:user] = @user.id end @@ -16,11 +16,11 @@ class SubmissionsControllerTest < ActionController::TestCase context '#create' do setup do @submission_count = Submission.count - template = FactoryBot.create :submission_template - study = FactoryBot.create :study - project = FactoryBot.create :project - sample_tube = FactoryBot.create :sample_tube - rt = FactoryBot.create :request_type + template = FactoryBot.create(:submission_template) + study = FactoryBot.create(:study) + project = FactoryBot.create(:project) + sample_tube = FactoryBot.create(:sample_tube) + rt = FactoryBot.create(:request_type) template.request_types << rt post :create, diff --git a/test/controllers/authentication_controller_test.rb b/test/controllers/authentication_controller_test.rb index 32ef3f863e..505e68c3d8 100644 --- a/test/controllers/authentication_controller_test.rb +++ b/test/controllers/authentication_controller_test.rb @@ -114,7 +114,7 @@ class AuthenticationControllerTest < ActionController::TestCase end context 'with valid api_key will not require login to restricted content' do setup do - @user = FactoryBot.create :user + @user = FactoryBot.create(:user) get :restricted, params: { api_key: @user.api_key } end should respond_with :success @@ -143,7 +143,7 @@ class AuthenticationControllerTest < ActionController::TestCase end context 'with valid api_key will not require login to restricted content' do setup do - @user = FactoryBot.create :user + @user = FactoryBot.create(:user) get :restricted, params: { api_key: @user.api_key } end should respond_with :success @@ -177,7 +177,7 @@ class AuthenticationControllerTest < ActionController::TestCase end context 'with valid api_key will not require login to restricted content' do setup do - @user = FactoryBot.create :user + @user = FactoryBot.create(:user) get :restricted, params: { api_key: @user.api_key } end should respond_with :success diff --git a/test/controllers/batches_controller_test.rb b/test/controllers/batches_controller_test.rb index 83f9220666..ca11a5e558 100644 --- a/test/controllers/batches_controller_test.rb +++ b/test/controllers/batches_controller_test.rb @@ -16,12 +16,12 @@ class BatchesControllerTest < ActionController::TestCase context 'NPG xml view' do setup do - pipeline = create :sequencing_pipeline + pipeline = create(:sequencing_pipeline) @study = create(:study) @project = create(:project) - @sample = create :sample - @submission = create :submission_without_order, priority: 3 + @sample = create(:sample) + @submission = create(:submission_without_order, priority: 3) @library = create(:empty_library_tube).tap do |library_tube| @@ -34,7 +34,7 @@ class BatchesControllerTest < ActionController::TestCase ) end - @phix = create :spiked_buffer, :tube_barcode + @phix = create(:spiked_buffer, :tube_barcode) @lane = create(:empty_lane, qc_state: 'failed') @lane.labware.parents << @library @@ -53,7 +53,7 @@ class BatchesControllerTest < ActionController::TestCase } ) - @batch = create :batch, pipeline: pipeline + @batch = create(:batch, pipeline:) @batch.batch_requests.create!(request: @request_one, position: 1) @batch.reload @batch.start!(create(:user)) @@ -120,7 +120,7 @@ class BatchesControllerTest < ActionController::TestCase context 'when the lane has multiple SpikedBuffer ancestors' do setup do - @phix_with_parent = create :spiked_buffer_with_parent, :tube_barcode + @phix_with_parent = create(:spiked_buffer_with_parent, :tube_barcode) @library.parents << @phix_with_parent get :show, params: { id: @batch.id, format: :xml } @@ -141,14 +141,14 @@ class BatchesControllerTest < ActionController::TestCase context 'with a user logged in' do setup do - @user = create :user + @user = create(:user) session[:user] = @user.id end context 'with a few batches' do setup do - @batch_one = create :batch - @batch_two = create :batch + @batch_one = create(:batch) + @batch_two = create(:batch) end should '#index' do @@ -172,9 +172,9 @@ class BatchesControllerTest < ActionController::TestCase context '#verify_tube_layout' do setup do - @pipeline = create :pipeline - @asset1 = create :sample_tube, barcode: '123456' - @asset2 = create :sample_tube, barcode: '654321' + @pipeline = create(:pipeline) + @asset1 = create(:sample_tube, barcode: '123456') + @asset2 = create(:sample_tube, barcode: '654321') @request1 = @pipeline.request_types.last.create!(asset: @asset1) @request2 = @pipeline.request_types.last.create!(asset: @asset2) @@ -216,7 +216,7 @@ class BatchesControllerTest < ActionController::TestCase context 'with a cherrypick pipeline' do setup do - @pipeline = create :cherrypick_pipeline + @pipeline = create(:cherrypick_pipeline) @requests = create_list(:cherrypick_request_for_pipeline, 2, request_type: @pipeline.request_types.first) @selected_request = @requests.first @submission = @selected_request.submission || raise('No Sub') @@ -240,10 +240,10 @@ class BatchesControllerTest < ActionController::TestCase context 'actions' do setup do - @pipeline_next = create :pipeline, name: 'Next pipeline' - @pipeline = create :pipeline, name: 'New Pipeline' - @pipeline_qc_manual = create :pipeline, name: 'Manual quality control' - @pipeline_qc = create :pipeline, name: 'quality control' + @pipeline_next = create(:pipeline, name: 'Next pipeline') + @pipeline = create(:pipeline, name: 'New Pipeline') + @pipeline_qc_manual = create(:pipeline, name: 'Manual quality control') + @pipeline_qc = create(:pipeline, name: 'quality control') @ws = @pipeline.workflow # :name => 'A New workflow', :item_limit => 2 @ws_two = @pipeline_qc.workflow # :name => 'Another workflow', :item_limit => 2 @@ -252,10 +252,10 @@ class BatchesControllerTest < ActionController::TestCase @batch_one = create(:batch, pipeline: @pipeline) @batch_two = create(:batch, pipeline: @pipeline_qc) - @sample = create :sample_tube - @library1 = create :empty_library_tube + @sample = create(:sample_tube) + @library1 = create(:empty_library_tube) @library1.parents << @sample - @library2 = create :empty_library_tube + @library2 = create(:empty_library_tube) @library2.parents << @sample @target_one = create(:sample_tube) @@ -280,7 +280,7 @@ class BatchesControllerTest < ActionController::TestCase end should '#update' do - @pipeline_user = create :pipeline_admin, login: 'ur1', first_name: 'Ursula', last_name: 'Robinson' + @pipeline_user = create(:pipeline_admin, login: 'ur1', first_name: 'Ursula', last_name: 'Robinson') put :update, params: { id: @batch_one.id, batch: { assignee_id: @pipeline_user.id } } assert_redirected_to batch_path(assigns(:batch)) assert_equal assigns(:batch).assignee, @pipeline_user @@ -507,8 +507,8 @@ class BatchesControllerTest < ActionController::TestCase context 'Find by barcode (found)' do setup do @controller.stubs(:current_user).returns(@admin) - @batch = FactoryBot.create :batch - request = FactoryBot.create :request + @batch = FactoryBot.create(:batch) + request = FactoryBot.create(:request) @batch.requests << request r = @batch.requests.first @e = r.lab_events.create(description: 'Cluster generation') @@ -541,24 +541,26 @@ class BatchesControllerTest < ActionController::TestCase attr_reader :barcode_printer setup do - @user = create :user + @user = create(:user) @controller.stubs(:current_user).returns(@user) - @barcode_printer = create :barcode_printer + @barcode_printer = create(:barcode_printer) end should '#print_plate_barcodes should send print request' do - study = create :study - project = create :project - asset = create :empty_sample_tube + study = create(:study) + project = create(:project) + asset = create(:empty_sample_tube) order_role = OrderRole.new role: 'test' - order = create :order, order_role: order_role, study: study, assets: [asset], project: project + order = create(:order, order_role: order_role, study: study, assets: [asset], project: project) request = - create :well_request, - asset: (create :well_with_sample_and_plate), - target_asset: (create :well_with_sample_and_plate), - order: order - @batch = create :batch + create( + :well_request, + asset: create(:well_with_sample_and_plate), + target_asset: create(:well_with_sample_and_plate), + order: order + ) + @batch = create(:batch) @batch.requests << request RestClient.expects(:post) @@ -575,8 +577,8 @@ class BatchesControllerTest < ActionController::TestCase end should '#print_barcodes should send print request' do - request = create :library_creation_request, target_asset: (create :library_tube, barcode: '111') - @batch = create :batch + request = create(:library_creation_request, target_asset: create(:library_tube, barcode: '111')) + @batch = create(:batch) @batch.requests << request printable = { request.id => 'on' } diff --git a/test/controllers/labware_controller_test.rb b/test/controllers/labware_controller_test.rb index 6ad91b0cc7..7d256cc32b 100644 --- a/test/controllers/labware_controller_test.rb +++ b/test/controllers/labware_controller_test.rb @@ -6,7 +6,7 @@ class LabwareControllerTest < ActionController::TestCase setup do @controller = LabwareController.new @request = ActionController::TestRequest.create(@controller) - @user = create :admin, api_key: 'abc' + @user = create(:admin, api_key: 'abc') session[:user] = @user.id end @@ -16,18 +16,18 @@ class LabwareControllerTest < ActionController::TestCase attr_reader :barcode_printer setup do - @user = create :user + @user = create(:user) @controller.stubs(:current_user).returns(@user) - @barcode_printer = create :barcode_printer + @barcode_printer = create(:barcode_printer) end should '#print_assets should send print request' do - asset = create :child_plate + asset = create(:child_plate) RestClient.expects(:post) post :print_assets, params: { printables: asset, printer: barcode_printer.name, id: asset.id.to_s } end should '#print_labels should send print request' do - asset = create :sample_tube + asset = create(:sample_tube) RestClient.expects(:post) post :print_labels, params: { @@ -44,7 +44,7 @@ class LabwareControllerTest < ActionController::TestCase attr_reader :asset setup do - @asset = create :sample_tube + @asset = create(:sample_tube) @controller.stubs(:current_user).returns(@user) end diff --git a/test/controllers/pipelines_controller_test.rb b/test/controllers/pipelines_controller_test.rb index ce4a72ba88..12c43a451c 100644 --- a/test/controllers/pipelines_controller_test.rb +++ b/test/controllers/pipelines_controller_test.rb @@ -8,7 +8,7 @@ class PipelinesControllerTest < ActionController::TestCase setup do @controller = PipelinesController.new @request = ActionController::TestRequest.create(@controller) - @user = FactoryBot.create :user + @user = FactoryBot.create(:user) session[:user] = @user.id end should_require_login @@ -20,7 +20,7 @@ class PipelinesControllerTest < ActionController::TestCase end context '#batches' do - setup { @pipeline = FactoryBot.create :pipeline } + setup { @pipeline = FactoryBot.create(:pipeline) } context 'without any pipeline batches' do setup { get :batches, params: { id: @pipeline.id.to_s } } @@ -29,7 +29,7 @@ class PipelinesControllerTest < ActionController::TestCase context 'with 1 batch' do setup do - FactoryBot.create :batch, pipeline: @pipeline + FactoryBot.create(:batch, pipeline: @pipeline) get :batches, params: { id: @pipeline.id.to_s } end @@ -39,14 +39,14 @@ class PipelinesControllerTest < ActionController::TestCase context '#show' do setup do - @pipeline = FactoryBot.create :pipeline + @pipeline = FactoryBot.create(:pipeline) get :show, params: { id: @pipeline } end should respond_with :success context 'and no batches' do setup do - @pipeline = FactoryBot.create :pipeline + @pipeline = FactoryBot.create(:pipeline) get :show, params: { id: @pipeline } end @@ -56,7 +56,7 @@ class PipelinesControllerTest < ActionController::TestCase context '#activate' do setup do - @pipeline = FactoryBot.create :pipeline + @pipeline = FactoryBot.create(:pipeline) get :activate, params: { id: @pipeline.id.to_s } end @@ -65,7 +65,7 @@ class PipelinesControllerTest < ActionController::TestCase context '#deactivate' do setup do - @pipeline = FactoryBot.create :pipeline + @pipeline = FactoryBot.create(:pipeline) get :deactivate, params: { id: @pipeline.id.to_s } end diff --git a/test/controllers/plate_summaries_controller_test.rb b/test/controllers/plate_summaries_controller_test.rb index 5d0ce8c28e..97602d9f71 100644 --- a/test/controllers/plate_summaries_controller_test.rb +++ b/test/controllers/plate_summaries_controller_test.rb @@ -8,17 +8,17 @@ class PlateSummariesControllerTest < ActionController::TestCase setup do @controller = PlateSummariesController.new @request = ActionController::TestRequest.create(@controller) - @user = create :user + @user = create(:user) session[:user] = @user.id end context 'with some plates' do setup do - purpose = create :source_plate_purpose - @source_plate_a = create :source_plate, purpose: purpose - @source_plate_b = create :source_plate, purpose: purpose - @child_plate_a = create :child_plate, parent: @source_plate_a - @child_plate_b = create :child_plate, parent: @source_plate_b + purpose = create(:source_plate_purpose) + @source_plate_a = create(:source_plate, purpose:) + @source_plate_b = create(:source_plate, purpose:) + @child_plate_a = create(:child_plate, parent: @source_plate_a) + @child_plate_b = create(:child_plate, parent: @source_plate_b) end should 'test factory is created' do @@ -26,7 +26,7 @@ class PlateSummariesControllerTest < ActionController::TestCase end context '#index' do - setup { create :plate_owner, user: @user, plate: @child_plate_a } + setup { create(:plate_owner, user: @user, plate: @child_plate_a) } should 'include owned plates' do get :index diff --git a/test/controllers/plates_controller_test.rb b/test/controllers/plates_controller_test.rb index 5267c7c938..414bc52579 100644 --- a/test/controllers/plates_controller_test.rb +++ b/test/controllers/plates_controller_test.rb @@ -8,13 +8,13 @@ class PlatesControllerTest < ActionController::TestCase @controller = PlatesController.new @request = ActionController::TestRequest.create(@controller) - @pico_purposes = create_list :pico_assay_purpose, 2 - @working_dilution = create_list :working_dilution_plate_purpose, 1 + @pico_purposes = create_list(:pico_assay_purpose, 2) + @working_dilution = create_list(:working_dilution_plate_purpose, 1) - @pico_assay_plate_creator = FactoryBot.create :plate_creator, plate_purposes: @pico_purposes - @dilution_plates_creator = FactoryBot.create :plate_creator, plate_purposes: @working_dilution + @pico_assay_plate_creator = FactoryBot.create(:plate_creator, plate_purposes: @pico_purposes) + @dilution_plates_creator = FactoryBot.create(:plate_creator, plate_purposes: @working_dilution) - @barcode_printer = create :barcode_printer + @barcode_printer = create(:barcode_printer) PlateBarcode.stubs(:create_barcode).returns( build(:plate_barcode, barcode: 'SQPD-1234567'), @@ -31,13 +31,13 @@ class PlatesControllerTest < ActionController::TestCase context 'with a logged in user' do setup do - @user = FactoryBot.create :user, barcode: 'ID100I', swipecard_code: '1234567' + @user = FactoryBot.create(:user, barcode: 'ID100I', swipecard_code: '1234567') @user.grant_administrator session[:user] = @user.id - @parent_plate = FactoryBot.create :plate - @parent_plate2 = FactoryBot.create :plate - @parent_plate3 = FactoryBot.create :plate + @parent_plate = FactoryBot.create(:plate) + @parent_plate2 = FactoryBot.create(:plate) + @parent_plate3 = FactoryBot.create(:plate) end context '#new' do @@ -223,7 +223,7 @@ class PlatesControllerTest < ActionController::TestCase should 'keep the created labware persisted' do barcode = @tube_rack.children.first.barcodes.first.barcode - assert_equal(1, Plate.joins(:barcodes).where(barcodes: { barcode: barcode }).count) + assert_equal(1, Plate.joins(:barcodes).where(barcodes: { barcode: }).count) end should set_flash[:warning].to(/Barcode labels failed to print/) @@ -246,7 +246,7 @@ class PlatesControllerTest < ActionController::TestCase context 'with one source plate' do setup do - @well = create :well + @well = create(:well) @parent_plate.wells << [@well] @parent_raw_barcode = @parent_plate.machine_barcode end @@ -325,7 +325,7 @@ class PlatesControllerTest < ActionController::TestCase context 'when we have 2 parents' do setup do - @well2 = create :well + @well2 = create(:well) @parent_plate2.wells << [@well2] @parent2_raw_barcode = @parent_plate2.machine_barcode end diff --git a/test/controllers/projects_controller_test.rb b/test/controllers/projects_controller_test.rb index 97c380512b..f87eb869c1 100644 --- a/test/controllers/projects_controller_test.rb +++ b/test/controllers/projects_controller_test.rb @@ -17,7 +17,7 @@ class ProjectsControllerTest < ActionController::TestCase setup do @controller = ProjectsController.new @request = ActionController::TestRequest.create(@controller) - @user = FactoryBot.create :user + @user = FactoryBot.create(:user) session[:user] = @user.id end @@ -29,7 +29,7 @@ class ProjectsControllerTest < ActionController::TestCase end context '#create' do - setup { @request_type_1 = FactoryBot.create :request_type } + setup { @request_type_1 = FactoryBot.create(:request_type) } context 'successfully create a new project' do setup do @@ -103,7 +103,7 @@ class ProjectsControllerTest < ActionController::TestCase context "POST '/create'" do context 'with JSON data' do setup do - @user = FactoryBot.create :user, api_key: 'abc' + @user = FactoryBot.create(:user, api_key: 'abc') session[:user] = @user.id @json_data = <<-END_OF_JSON_DATA diff --git a/test/controllers/qc_files_controller_test.rb b/test/controllers/qc_files_controller_test.rb index 457bedd0eb..d889a06ab5 100644 --- a/test/controllers/qc_files_controller_test.rb +++ b/test/controllers/qc_files_controller_test.rb @@ -24,7 +24,7 @@ class QcFilesControllerTest < ActionController::TestCase @controller = QcFilesController.new @request = ActionController::TestRequest.create(@controller) - @user = create :user + @user = create(:user) session[:user] = @user.id end diff --git a/test/controllers/qc_reports_controller_test.rb b/test/controllers/qc_reports_controller_test.rb index 13fe8c231e..3cfb2fabab 100644 --- a/test/controllers/qc_reports_controller_test.rb +++ b/test/controllers/qc_reports_controller_test.rb @@ -10,11 +10,11 @@ class QcReportsControllerTest < ActionController::TestCase @request = ActionController::TestRequest.create(@controller) @request.env['HTTP_REFERER'] = '/' - @user = create :user + @user = create(:user) session[:user] = @user.id - @study = create :study - @product = create :product - @product_criteria = create :product_criteria, product: @product + @study = create(:study) + @product = create(:product) + @product_criteria = create(:product_criteria, product: @product) end should_require_login(:index) diff --git a/test/controllers/receptacles_controller_test.rb b/test/controllers/receptacles_controller_test.rb index 888c5db1c5..fc1f6a5d15 100644 --- a/test/controllers/receptacles_controller_test.rb +++ b/test/controllers/receptacles_controller_test.rb @@ -6,7 +6,7 @@ class ReceptaclesControllerTest < ActionController::TestCase setup do @controller = ReceptaclesController.new @request = ActionController::TestRequest.create(@controller) - @user = create :admin, api_key: 'abc' + @user = create(:admin, api_key: 'abc') session[:user] = @user.id end @@ -18,9 +18,9 @@ class ReceptaclesControllerTest < ActionController::TestCase @asset = create(:sample_tube).receptacle @sample = @asset.primary_aliquot.sample - @study = create :study - @project = create :project, enforce_quotas: true - @request_type = create :request_type + @study = create(:study) + @project = create(:project, enforce_quotas: true) + @request_type = create(:request_type) @json_data = valid_json_create_request(@asset, @request_type, @study, @project) @request.accept = @request.env['CONTENT_TYPE'] = 'application/json' diff --git a/test/controllers/requests_comments_controller_test.rb b/test/controllers/requests_comments_controller_test.rb index 821795d068..d2600029a0 100644 --- a/test/controllers/requests_comments_controller_test.rb +++ b/test/controllers/requests_comments_controller_test.rb @@ -8,7 +8,7 @@ class CommentsControllerTest < ActionController::TestCase setup do @controller = Requests::CommentsController.new @request = ActionController::TestRequest.create(@controller) - @user = create :user + @user = create(:user) session[:user] = @user.id end @@ -24,9 +24,9 @@ class CommentsControllerTest < ActionController::TestCase context 'with an ajax request' do setup do - @rq = create :request + @rq = create(:request) - %w[this is a test].each { |description| create :comment, description: description, commentable: @rq } + %w[this is a test].each { |description| create(:comment, description: description, commentable: @rq) } end should 'return a ul of comments' do diff --git a/test/controllers/requests_controller_test.rb b/test/controllers/requests_controller_test.rb index 6f3f5ee04f..0e3c71e4f3 100644 --- a/test/controllers/requests_controller_test.rb +++ b/test/controllers/requests_controller_test.rb @@ -8,7 +8,7 @@ class RequestsControllerTest < ActionController::TestCase setup do @controller = RequestsController.new @request = ActionController::TestRequest.create(@controller) - @user = FactoryBot.create :admin + @user = FactoryBot.create(:admin) end should_require_login @@ -18,10 +18,12 @@ class RequestsControllerTest < ActionController::TestCase should 'cancel request' do request = - FactoryBot.create :request, - user: @user, - request_type: FactoryBot.create(:request_type), - study: FactoryBot.create(:study, name: 'ReqCon2') + FactoryBot.create( + :request, + user: @user, + request_type: FactoryBot.create(:request_type), + study: FactoryBot.create(:study, name: 'ReqCon2') + ) get :cancel, params: { id: request.id } assert_equal flash[:notice], "Request #{request.id} has been cancelled" @@ -31,11 +33,13 @@ class RequestsControllerTest < ActionController::TestCase should 'cancel started request' do request = - FactoryBot.create :request, - state: 'started', - user: @user, - request_type: FactoryBot.create(:request_type), - study: FactoryBot.create(:study, name: 'ReqCon2') + FactoryBot.create( + :request, + state: 'started', + user: @user, + request_type: FactoryBot.create(:request_type), + study: FactoryBot.create(:study, name: 'ReqCon2') + ) get :cancel, params: { id: request.id } assert_equal flash[:error], "Request #{request.id} can't be cancelled" @@ -48,10 +52,12 @@ class RequestsControllerTest < ActionController::TestCase should 'when quotas is copied and redirect' do @request_initial = - FactoryBot.create :request, - user: @user, - request_type: FactoryBot.create(:request_type), - study: FactoryBot.create(:study, name: 'ReqCon2') + FactoryBot.create( + :request, + user: @user, + request_type: FactoryBot.create(:request_type), + study: FactoryBot.create(:study, name: 'ReqCon2') + ) get :copy, params: { id: @request_initial.id } @new_request = Request.last @@ -61,11 +67,13 @@ class RequestsControllerTest < ActionController::TestCase should 'set failed requests to pending' do @request_initial = - FactoryBot.create :request, - user: @user, - request_type: FactoryBot.create(:request_type), - study: FactoryBot.create(:study, name: 'ReqCon2'), - state: 'failed' + FactoryBot.create( + :request, + user: @user, + request_type: FactoryBot.create(:request_type), + study: FactoryBot.create(:study, name: 'ReqCon2'), + state: 'failed' + ) get :copy, params: { id: @request_initial.id } @new_request = Request.last @@ -82,10 +90,12 @@ class RequestsControllerTest < ActionController::TestCase @prop_value_after = 666 @our_request = - FactoryBot.create :request, - user: @user, - request_type: FactoryBot.create(:request_type), - study: FactoryBot.create(:study, name: 'ReqCon') + FactoryBot.create( + :request, + user: @user, + request_type: FactoryBot.create(:request_type), + study: FactoryBot.create(:study, name: 'ReqCon') + ) @params = { request_metadata_attributes: { read_length: '37' @@ -123,11 +133,13 @@ class RequestsControllerTest < ActionController::TestCase @project = FactoryBot.create(:project_with_order, name: 'Prj1') @reqwest = - FactoryBot.create :request, - user: @user, - request_type: FactoryBot.create(:request_type), - study: FactoryBot.create(:study, name: 'ReqCon XXX'), - project: @project + FactoryBot.create( + :request, + user: @user, + request_type: FactoryBot.create(:request_type), + study: FactoryBot.create(:study, name: 'ReqCon XXX'), + project: @project + ) end context 'update invalid and failed' do diff --git a/test/controllers/robots_controller_test.rb b/test/controllers/robots_controller_test.rb index 2ec0154ea1..ec3a91fbb6 100644 --- a/test/controllers/robots_controller_test.rb +++ b/test/controllers/robots_controller_test.rb @@ -7,9 +7,9 @@ class RobotsControllerTest < ActionController::TestCase context 'Robots' do setup do - @user = FactoryBot.create :admin + @user = FactoryBot.create(:admin) session[:user] = @user - @robot = FactoryBot.create :robot + @robot = FactoryBot.create(:robot) end should_require_login diff --git a/test/controllers/sample_manifests_controller_test.rb b/test/controllers/sample_manifests_controller_test.rb index b3a320cff0..eef13b7cfb 100644 --- a/test/controllers/sample_manifests_controller_test.rb +++ b/test/controllers/sample_manifests_controller_test.rb @@ -8,7 +8,7 @@ class SampleManifestsControllerTest < ActionController::TestCase setup do @controller = Sdb::SampleManifestsController.new @request = ActionController::TestRequest.create(@controller) - @user = create :user + @user = create(:user) session[:user] = @user.id SampleManifestExcel.configure do |config| @@ -18,7 +18,7 @@ class SampleManifestsControllerTest < ActionController::TestCase end context '#show' do - setup { @sample_manifest = create :sample_manifest_with_samples } + setup { @sample_manifest = create(:sample_manifest_with_samples) } should 'return expected sample manifest' do get :show, params: { id: @sample_manifest.id } @@ -44,11 +44,11 @@ class SampleManifestsControllerTest < ActionController::TestCase build(:plate_barcode, barcode: 'SQPD-26'), build(:plate_barcode, barcode: 'SQPD-27') ) - study = create :study + study = create(:study) supplier = Supplier.new(name: 'test') supplier.save - barcode_printer = create :barcode_printer + barcode_printer = create(:barcode_printer) LabelPrinter::PmbClient.stubs(:get_label_template_by_name).returns('data' => [{ 'id' => 15 }]) RestClient.expects(:post) diff --git a/test/controllers/samples_controller_test.rb b/test/controllers/samples_controller_test.rb index 3c0bfb9795..a66a80ed91 100644 --- a/test/controllers/samples_controller_test.rb +++ b/test/controllers/samples_controller_test.rb @@ -42,7 +42,7 @@ class SamplesControllerTest < ActionController::TestCase # TODO: Test without admin context 'when logged in' do setup do - @user = FactoryBot.create :user + @user = FactoryBot.create(:user) @controller.stubs(:logged_in?).returns(@user) session[:user] = @user.id end @@ -50,8 +50,8 @@ class SamplesControllerTest < ActionController::TestCase context '#add_to_study' do setup do @initial_study_sample_count = StudySample.count - @sample = FactoryBot.create :sample - @study = FactoryBot.create :study + @sample = FactoryBot.create(:sample) + @study = FactoryBot.create(:study) put :add_to_study, params: { id: @sample.id, study: { id: @study.id } } end should 'change StudySample.count from 0 to 1' do diff --git a/test/controllers/studies_asset_groups_controller_test.rb b/test/controllers/studies_asset_groups_controller_test.rb index 458a785b1c..38c0e1a2cc 100644 --- a/test/controllers/studies_asset_groups_controller_test.rb +++ b/test/controllers/studies_asset_groups_controller_test.rb @@ -13,11 +13,11 @@ class AssetGroupsControllerTest < ActionController::TestCase @study_count_a = Study.count @controller = Studies::AssetGroupsController.new @request = ActionController::TestRequest.create(@controller) - @user = FactoryBot.create :user + @user = FactoryBot.create(:user) session[:user] = @user.id @controller.stubs(:logged_in?).returns(@user) - @study = FactoryBot.create :study - @asset_group = FactoryBot.create :asset_group + @study = FactoryBot.create(:study) + @asset_group = FactoryBot.create(:asset_group) end %w[index new].each do |controller_method| @@ -124,10 +124,10 @@ class AssetGroupsControllerTest < ActionController::TestCase context '#print_labels' do should 'send print request' do - @user = create :user + @user = create(:user) @controller.stubs(:current_user).returns(@user) - @asset = create :child_plate - barcode_printer = create :barcode_printer + @asset = create(:child_plate) + barcode_printer = create(:barcode_printer) RestClient.expects(:post) diff --git a/test/controllers/studies_events_controller_test.rb b/test/controllers/studies_events_controller_test.rb index e82c0dbc3e..55e51bcd93 100644 --- a/test/controllers/studies_events_controller_test.rb +++ b/test/controllers/studies_events_controller_test.rb @@ -9,9 +9,9 @@ class EventsControllerTest < ActionController::TestCase @controller = Studies::EventsController.new @request = ActionController::TestRequest.create(@controller) - @user = create :user + @user = create(:user) session[:user] = @user.id - @study = create :study + @study = create(:study) end should_require_login(:index, resource: 'event', parent: 'study') diff --git a/test/controllers/studies_sample_controller_test.rb b/test/controllers/studies_sample_controller_test.rb index 262a8b3969..b621ab2fb9 100644 --- a/test/controllers/studies_sample_controller_test.rb +++ b/test/controllers/studies_sample_controller_test.rb @@ -9,7 +9,7 @@ class SamplesControllerTest < ActionController::TestCase @controller = Studies::SamplesController.new @request = ActionController::TestRequest.create(@controller) - @user = create :user + @user = create(:user) session[:user] = @user.id end diff --git a/test/controllers/workflows_controller_test.rb b/test/controllers/workflows_controller_test.rb index 1372097f3f..bcd0f813d6 100644 --- a/test/controllers/workflows_controller_test.rb +++ b/test/controllers/workflows_controller_test.rb @@ -10,15 +10,15 @@ class WorkflowsControllerTest < ActionController::TestCase @controller = WorkflowsController.new @request = ActionController::TestRequest.create(@controller) - @user = FactoryBot.create :user + @user = FactoryBot.create(:user) session[:user] = @user.id - @pipeline_user = FactoryBot.create :pipeline_admin + @pipeline_user = FactoryBot.create(:pipeline_admin) end context '#stage' do # rubocop:todo Metrics/BlockLength setup do - @pipeline = FactoryBot.create :pipeline, name: 'Generic workflow' + @pipeline = FactoryBot.create(:pipeline, name: 'Generic workflow') @ws1 = @pipeline.workflow # :item_limit => 5 @ws2 = FactoryBot.create(:pipeline, name: 'Old workflow').workflow @@ -26,38 +26,46 @@ class WorkflowsControllerTest < ActionController::TestCase @batch = @pipeline.batches.create! @task1 = - FactoryBot.create :task, - name: 'Q20 Check', - location: '', - workflow: @ws1, - sorted: 0, - sti_type: 'SetDescriptorsTask' + FactoryBot.create( + :task, + name: 'Q20 Check', + location: '', + workflow: @ws1, + sorted: 0, + sti_type: 'SetDescriptorsTask' + ) @task2 = - FactoryBot.create :task, - name: 'Submit batch', - location: 'http://someurl', - workflow: @ws1, - sorted: 1, - sti_type: 'SetDescriptorsTask' + FactoryBot.create( + :task, + name: 'Submit batch', + location: 'http://someurl', + workflow: @ws1, + sorted: 1, + sti_type: 'SetDescriptorsTask' + ) @task3 = - FactoryBot.create :task, - name: 'Q20 Check', - location: '', - workflow: @ws2, - sorted: 0, - sti_type: 'SetDescriptorsTask' + FactoryBot.create( + :task, + name: 'Q20 Check', + location: '', + workflow: @ws2, + sorted: 0, + sti_type: 'SetDescriptorsTask' + ) @task4 = - FactoryBot.create :task, - name: 'Submit batch', - location: 'http://someurl', - workflow: @ws2, - sorted: 1, - sti_type: 'SetDescriptorsTask' - @library1 = FactoryBot.create :library_tube - @lane1 = FactoryBot.create :lane + FactoryBot.create( + :task, + name: 'Submit batch', + location: 'http://someurl', + workflow: @ws2, + sorted: 1, + sti_type: 'SetDescriptorsTask' + ) + @library1 = FactoryBot.create(:library_tube) + @lane1 = FactoryBot.create(:lane) @lane1.labware.parents << @library1 - @library2 = FactoryBot.create :library_tube - @lane2 = FactoryBot.create :lane + @library2 = FactoryBot.create(:library_tube) + @lane2 = FactoryBot.create(:lane) @lane2.labware.parents << @library2 @item1 = @pipeline.request_types.last.create!(asset: @library1, target_asset: @lane1) @@ -65,11 +73,11 @@ class WorkflowsControllerTest < ActionController::TestCase @item2 = @pipeline.request_types.last.create!(asset: @library2, target_asset: @lane2) @batch.batch_requests.create!(request: @item2, position: 2) - FactoryBot.create :descriptor, task: @task2, name: 'Chip Barcode', kind: 'ExternalBarcode', selection: {} - FactoryBot.create :descriptor, task: @task2, name: 'Comment', kind: 'Text', selection: {} - FactoryBot.create :descriptor, task: @task2, name: 'Passed?', kind: 'Selection', selection: {} + FactoryBot.create(:descriptor, task: @task2, name: 'Chip Barcode', kind: 'ExternalBarcode', selection: {}) + FactoryBot.create(:descriptor, task: @task2, name: 'Comment', kind: 'Text', selection: {}) + FactoryBot.create(:descriptor, task: @task2, name: 'Passed?', kind: 'Selection', selection: {}) - @user = FactoryBot.create :admin + @user = FactoryBot.create(:admin) session[:user] = @user.id @batch_events_size = @batch.lab_events.size end diff --git a/test/functional/external_validator_test.rb b/test/functional/external_validator_test.rb index 623edeb318..0c9e697797 100644 --- a/test/functional/external_validator_test.rb +++ b/test/functional/external_validator_test.rb @@ -5,7 +5,7 @@ class ExternalValidatorTest < ActiveSupport::TestCase context 'A submission with a validated request type' do setup do - @validated_request_type = FactoryBot.create :validated_request_type + @validated_request_type = FactoryBot.create(:validated_request_type) @assets = [create(:sample_tube)] # We don't want to trigger validation just yet! diff --git a/test/functional/pre_cap_groups_test.rb b/test/functional/pre_cap_groups_test.rb index 60981ff284..8b8d29d852 100644 --- a/test/functional/pre_cap_groups_test.rb +++ b/test/functional/pre_cap_groups_test.rb @@ -16,8 +16,8 @@ def with_pools(*pools) context 'A plate' do setup do - @plate = create :pooling_plate - @pools = create_list :pre_capture_pool, 3 + @plate = create(:pooling_plate) + @pools = create_list(:pre_capture_pool, 3) end context 'with two distinct pools' do @@ -45,7 +45,7 @@ def with_pools(*pools) context 'when transfers are created' do setup do - @target_plate = create :plate_with_empty_wells + @target_plate = create(:plate_with_empty_wells) @transfer = Transfer::BetweenPlates.create!( source: @plate.reload, @@ -114,12 +114,12 @@ def with_pools(*pools) # We need to ensure we still see all pools, regardless of which # plate they were made on. setup do - @plate = create :input_plate_for_pooling - @test_plate = create :non_stock_pooling_plate - @pools = create_list :pre_capture_pool, 3 + @plate = create(:input_plate_for_pooling) + @test_plate = create(:non_stock_pooling_plate) + @pools = create_list(:pre_capture_pool, 3) with_pools(%w[A1 B1 C1], %w[D1 E1 F1]) transfers = @test_plate.wells.each_with_object({}) { |w, hash| hash[w.map_description] = w.map_description } - create :transfer_between_plates, transfers: transfers, source: @plate, destination: @test_plate + create(:transfer_between_plates, transfers: transfers, source: @plate, destination: @test_plate) end should 'report the pools from the stock plate' do diff --git a/test/lib/label_printer/batch_tube_test.rb b/test/lib/label_printer/batch_tube_test.rb index fdc7b42337..c735772fe6 100644 --- a/test/lib/label_printer/batch_tube_test.rb +++ b/test/lib/label_printer/batch_tube_test.rb @@ -7,12 +7,12 @@ class BatchTubeTest < ActiveSupport::TestCase context 'stock' do should 'return the right tubes and top line' do - library_tube_with_stock_tube = create :library_tube - stock_library_tube = create :stock_library_tube + library_tube_with_stock_tube = create(:library_tube) + stock_library_tube = create(:stock_library_tube) stock_library_tube.children << library_tube_with_stock_tube - request = create :library_creation_request, target_asset: library_tube_with_stock_tube - @batch = create :batch + request = create(:library_creation_request, target_asset: library_tube_with_stock_tube) + @batch = create(:batch) @batch.requests << request printable = { request.id => 'on' } @@ -27,8 +27,8 @@ class BatchTubeTest < ActiveSupport::TestCase context 'no stock' do should 'return the right tubes and top line' do - request = create :library_creation_request, target_asset: (create :library_tube, barcode: '111') - @batch = create :batch + request = create(:library_creation_request, target_asset: create(:library_tube, barcode: '111')) + @batch = create(:batch) @batch.requests << request printable = { request.id => 'on' } diff --git a/test/lib/label_printer/labels_multiplication_test.rb b/test/lib/label_printer/labels_multiplication_test.rb index c2cd55b1a2..66d7930ecf 100644 --- a/test/lib/label_printer/labels_multiplication_test.rb +++ b/test/lib/label_printer/labels_multiplication_test.rb @@ -17,10 +17,10 @@ class ExampleLabelTest < ActiveSupport::TestCase def setup @example_label = ExampleLabel.new - @plate1 = create :plate, name: 'Plate 1', barcode: 'SQPD-1111' - @plate2 = create :plate, name: 'Plate 2', barcode: 'SQPD-2222' - @plate3 = create :plate, name: 'Plate 3', barcode: 'SQPD-3333' - @plate4 = create :plate, name: 'Plate 4', barcode: 'SQPD-4444' + @plate1 = create(:plate, name: 'Plate 1', barcode: 'SQPD-1111') + @plate2 = create(:plate, name: 'Plate 2', barcode: 'SQPD-2222') + @plate3 = create(:plate, name: 'Plate 3', barcode: 'SQPD-3333') + @plate4 = create(:plate, name: 'Plate 4', barcode: 'SQPD-4444') @label = { left: 'Plate 1', right: 'SQPD', barcode: '1111', label_name: 'main_label' } @labels = [ diff --git a/test/lib/label_printer/plate_creator_test.rb b/test/lib/label_printer/plate_creator_test.rb index ed3b3c5162..a22e4c4934 100644 --- a/test/lib/label_printer/plate_creator_test.rb +++ b/test/lib/label_printer/plate_creator_test.rb @@ -19,31 +19,33 @@ class PlateCreatorTest < ActiveSupport::TestCase def setup # rubocop:todo Metrics/AbcSize, Metrics/MethodLength @parent_barcode = 'SQPD-1234' - @studies = create_list :study, 1 - parent = create :source_plate, barcode: parent_barcode, studies: @studies - well = create :well_with_sample_and_plate, plate: parent + @studies = create_list(:study, 1) + parent = create(:source_plate, barcode: parent_barcode, studies: @studies) + well = create(:well_with_sample_and_plate, plate: parent) @barcode1 = 'SQPD-1111' @purpose_name = 'test purpose' - plate_purpose = create :plate_purpose, name: purpose_name + plate_purpose = create(:plate_purpose, name: purpose_name) @plate1 = - create :child_plate, - parent: parent, - barcode: barcode1, - plate_purpose: plate_purpose, - well_count: 1, - well_factory: :untagged_well, - studies: @studies + create( + :child_plate, + parent: parent, + barcode: barcode1, + plate_purpose: plate_purpose, + well_count: 1, + well_factory: :untagged_well, + studies: @studies + ) @plates = [plate1] @user = 'user' @study_abbreviation = 'WTCCC' options = { plate_purpose: plate_purpose, plates: plates, user_login: user } @plate_label = LabelPrinter::Label::PlateCreator.new(options) @label = { - top_left: (Date.today.strftime('%e-%^b-%Y')).to_s, - bottom_left: (plate1.human_barcode).to_s, - top_right: (purpose_name).to_s, + top_left: Date.today.strftime('%e-%^b-%Y').to_s, + bottom_left: plate1.human_barcode.to_s, + top_right: purpose_name.to_s, bottom_right: "#{user} #{study_abbreviation}", - top_far_right: (parent_barcode).to_s, + top_far_right: parent_barcode.to_s, barcode: plate1.machine_barcode, label_name: 'main_label' } @@ -56,6 +58,6 @@ def setup # rubocop:todo Metrics/AbcSize, Metrics/MethodLength test 'should return the correct specific values' do assert_equal purpose_name, plate_label.top_right(plate1) assert_equal "#{user} #{study_abbreviation}", plate_label.bottom_right(plate1) - assert_equal (parent_barcode).to_s, plate_label.top_far_right(plate1) + assert_equal parent_barcode.to_s, plate_label.top_far_right(plate1) end end diff --git a/test/lib/label_printer/plate_to_tube_test.rb b/test/lib/label_printer/plate_to_tube_test.rb index 47ec23c504..c9559a2887 100644 --- a/test/lib/label_printer/plate_to_tube_test.rb +++ b/test/lib/label_printer/plate_to_tube_test.rb @@ -12,15 +12,15 @@ def setup # rubocop:todo Metrics/AbcSize @prefix = 'NT' @barcode1 = '1111' @asset_name = 'tube name' - @tube1 = create :sample_tube, barcode: barcode1, name: asset_name - @sample_tubes = create_list :sample_tube, 4 + @tube1 = create(:sample_tube, barcode: barcode1, name: asset_name) + @sample_tubes = create_list(:sample_tube, 4) sample_tubes.unshift(tube1) - options = { sample_tubes: sample_tubes } + options = { sample_tubes: } @tube_label = LabelPrinter::Label::PlateToTubes.new(options) @label = { - first_line: (asset_name).to_s, + first_line: asset_name.to_s, second_line: barcode1, - third_line: (Date.today.strftime('%e-%^b-%Y')).to_s, + third_line: Date.today.strftime('%e-%^b-%Y').to_s, round_label_top_line: prefix, round_label_bottom_line: barcode1, barcode: tube1.machine_barcode, diff --git a/test/lib/label_printer/print_job_test.rb b/test/lib/label_printer/print_job_test.rb index 5d8631a145..14c32637c6 100644 --- a/test/lib/label_printer/print_job_test.rb +++ b/test/lib/label_printer/print_job_test.rb @@ -13,14 +13,14 @@ class PrintJobTest < ActiveSupport::TestCase :labels_attributes def setup # rubocop:todo Metrics/AbcSize, Metrics/MethodLength - @barcode_printer = create :barcode_printer - @plates = create_list :plate, 1, well_count: 1, well_factory: :untagged_well + @barcode_printer = create(:barcode_printer) + @plates = create_list(:plate, 1, well_count: 1, well_factory: :untagged_well) @plate = plates[0] @plate_purpose = plate.plate_purpose @label_template_name = barcode_printer.barcode_printer_type.label_template_name @labels_attributes = [ { - top_left: (Date.today.strftime('%e-%^b-%Y')).to_s, + top_left: Date.today.strftime('%e-%^b-%Y').to_s, bottom_left: plate.human_barcode.to_s, top_right: plate_purpose.name.to_s, bottom_right: 'user WTCCC', diff --git a/test/lib/label_printer/sample_manifest_multiplex_test.rb b/test/lib/label_printer/sample_manifest_multiplex_test.rb index 53a2b01e3d..9b05daade6 100644 --- a/test/lib/label_printer/sample_manifest_multiplex_test.rb +++ b/test/lib/label_printer/sample_manifest_multiplex_test.rb @@ -9,7 +9,7 @@ class SampleManifestMultiplexTest < ActiveSupport::TestCase attr_reader :only_first_label, :manifest, :tube_label, :tube1, :prefix, :barcode1, :label, :study_abbreviation def setup # rubocop:todo Metrics/AbcSize - @manifest = create :sample_manifest, asset_type: 'multiplexed_library', count: 3 + @manifest = create(:sample_manifest, asset_type: 'multiplexed_library', count: 3) @manifest.generate @@ -22,9 +22,9 @@ def setup # rubocop:todo Metrics/AbcSize @tube_label = LabelPrinter::Label::SampleManifestMultiplex.new(options) @label = { - first_line: (study_abbreviation).to_s, + first_line: study_abbreviation.to_s, second_line: barcode1, - third_line: (Date.today.strftime('%e-%^b-%Y')).to_s, + third_line: Date.today.strftime('%e-%^b-%Y').to_s, round_label_top_line: prefix, round_label_bottom_line: barcode1, barcode: tube1.machine_barcode, diff --git a/test/lib/label_printer/sample_manifest_plate_test.rb b/test/lib/label_printer/sample_manifest_plate_test.rb index d7985c3b94..8faa16bf3d 100644 --- a/test/lib/label_printer/sample_manifest_plate_test.rb +++ b/test/lib/label_printer/sample_manifest_plate_test.rb @@ -21,9 +21,9 @@ class SampleManifestPlateTest < ActiveSupport::TestCase build(:plate_barcode, barcode: 'SQPD-24') ) - @purpose = create :plate_purpose + @purpose = create(:plate_purpose) - @manifest = create :sample_manifest, count: 2, purpose: @purpose + @manifest = create(:sample_manifest, count: 2, purpose: @purpose) @manifest.generate @plates = @manifest.send(:core_behaviour).plates @@ -35,12 +35,12 @@ class SampleManifestPlateTest < ActiveSupport::TestCase options = { sample_manifest: manifest, only_first_label: false, purpose: @purpose } @plate_label = LabelPrinter::Label::SampleManifestPlate.new(options) @label = { - top_left: (Date.today.strftime('%e-%^b-%Y')).to_s, - bottom_left: (plate1.human_barcode).to_s, + top_left: Date.today.strftime('%e-%^b-%Y').to_s, + bottom_left: plate1.human_barcode.to_s, top_right: purpose.name, bottom_right: "#{study_abbreviation} #{barcode1}", top_far_right: nil, - barcode: (plate1.machine_barcode).to_s, + barcode: plate1.machine_barcode.to_s, label_name: 'main_label' } end diff --git a/test/lib/label_printer/sample_manifest_tube_test.rb b/test/lib/label_printer/sample_manifest_tube_test.rb index 567d4cbcf0..97f6a810cb 100644 --- a/test/lib/label_printer/sample_manifest_tube_test.rb +++ b/test/lib/label_printer/sample_manifest_tube_test.rb @@ -9,7 +9,7 @@ class SampleManifestTubeTest < ActiveSupport::TestCase attr_reader :manifest, :tube_label, :tube1, :tube2, :tube3, :tubes, :prefix, :barcode1, :label def setup # rubocop:todo Metrics/AbcSize, Metrics/MethodLength - @manifest = create :sample_manifest, asset_type: '1dtube', purpose: Tube::Purpose.standard_sample_tube, count: 3 + @manifest = create(:sample_manifest, asset_type: '1dtube', purpose: Tube::Purpose.standard_sample_tube, count: 3) @manifest.generate @tube1 = manifest.printables[0] @tube2 = manifest.printables[1] @@ -22,9 +22,9 @@ def setup # rubocop:todo Metrics/AbcSize, Metrics/MethodLength options = { sample_manifest: @manifest, only_first_label: false } @tube_label = LabelPrinter::Label::SampleManifestTube.new(options) @label = { - first_line: (manifest.study.abbreviation).to_s, + first_line: manifest.study.abbreviation.to_s, second_line: barcode1, - third_line: (Date.today.strftime('%e-%^b-%Y')).to_s, + third_line: Date.today.strftime('%e-%^b-%Y').to_s, round_label_top_line: prefix, round_label_bottom_line: barcode1, barcode: tube1.machine_barcode, diff --git a/test/lib/label_printer/shared_tests.rb b/test/lib/label_printer/shared_tests.rb index 5f106e1c9a..778cb93a2c 100644 --- a/test/lib/label_printer/shared_tests.rb +++ b/test/lib/label_printer/shared_tests.rb @@ -7,7 +7,7 @@ module SharedTubeTests def self.included(base) # rubocop:todo Metrics/AbcSize base.class_eval do test 'should return the correct values' do - assert_equal (barcode1).to_s, tube_label.second_line(tube1) + assert_equal barcode1.to_s, tube_label.second_line(tube1) assert_equal prefix, tube_label.round_label_top_line(tube1) assert_equal barcode1, tube_label.round_label_bottom_line(tube1) assert_match barcode1, tube_label.barcode(tube1) diff --git a/test/performance/plate_creation_test.rb b/test/performance/plate_creation_test.rb index c3aae1deec..9df00742c4 100644 --- a/test/performance/plate_creation_test.rb +++ b/test/performance/plate_creation_test.rb @@ -11,7 +11,7 @@ class PlateCreationTest < ActionDispatch::PerformanceTest # output: 'tmp/performance', formats: [:flat] } SIZE = 6 def setup - @purpose = create :plate_purpose + @purpose = create(:plate_purpose) end test 'PlatePurpose.create' do diff --git a/test/performance/state_change_test.rb b/test/performance/state_change_test.rb index 79803f59fe..5a53f07119 100644 --- a/test/performance/state_change_test.rb +++ b/test/performance/state_change_test.rb @@ -10,11 +10,11 @@ class StateChangeTest < ActionDispatch::PerformanceTest # self.profile_options = { runs: 5, metrics: [:wall_time, :memory], # output: 'tmp/performance', formats: [:flat] } def setup - @source = create :transfer_plate, well_count: 96 - @destination = create :plate, well_count: 96 + @source = create(:transfer_plate, well_count: 96) + @destination = create(:plate, well_count: 96) transfers = @source.wells.each_with_object({}) { |w, h| h[w.map_description] = w.map_description } - @transfer = create :transfer_between_plates, source: @source, destination: @destination, transfers: transfers - @user = create :user + @transfer = create(:transfer_between_plates, source: @source, destination: @destination, transfers: transfers) + @user = create(:user) end test 'StateChange.create' do diff --git a/test/performance/transfer_request_collection_test.rb b/test/performance/transfer_request_collection_test.rb index 2392bd9c16..a77fc935ce 100644 --- a/test/performance/transfer_request_collection_test.rb +++ b/test/performance/transfer_request_collection_test.rb @@ -18,7 +18,7 @@ def setup target_asset = FactoryBot.create_list(:empty_well, SIZE) @transfer_requests_attributes = Array.new(SIZE) { |i| { source_asset: asset[i].uuid, target_asset: target_asset[i].uuid } } - @user = FactoryBot.create :user + @user = FactoryBot.create(:user) @api_key = FactoryBot.create(:api_application).key end diff --git a/test/performance/work_completion_tubes_test.rb b/test/performance/work_completion_tubes_test.rb index 985a21fe95..aec669d758 100644 --- a/test/performance/work_completion_tubes_test.rb +++ b/test/performance/work_completion_tubes_test.rb @@ -9,104 +9,114 @@ class WorkCompletionTubesTest < ActionDispatch::PerformanceTest # THis setup mimic the end of the GBS pipeline. # rubocop:todo Metrics/PerceivedComplexity, Metrics/AbcSize def setup # rubocop:todo Metrics/CyclomaticComplexity, Metrics/MethodLength - @user = create :user + @user = create(:user) tested_wells = 2 - input_plate_1 = create :input_plate, well_count: tested_wells, well_factory: :tagged_well - input_plate_2 = create :input_plate, well_count: tested_wells, well_factory: :tagged_well - input_plate_3 = create :input_plate, well_count: tested_wells, well_factory: :tagged_well - input_plate_4 = create :input_plate, well_count: tested_wells, well_factory: :tagged_well + input_plate_1 = create(:input_plate, well_count: tested_wells, well_factory: :tagged_well) + input_plate_2 = create(:input_plate, well_count: tested_wells, well_factory: :tagged_well) + input_plate_3 = create(:input_plate, well_count: tested_wells, well_factory: :tagged_well) + input_plate_4 = create(:input_plate, well_count: tested_wells, well_factory: :tagged_well) - library_request_type = create :library_request_type + library_request_type = create(:library_request_type) submission_request_types = [library_request_type] target_submission_1 = - create :library_submission, assets: input_plate_1.wells, request_types: submission_request_types + create(:library_submission, assets: input_plate_1.wells, request_types: submission_request_types) target_submission_2 = - create :library_submission, assets: input_plate_2.wells, request_types: submission_request_types + create(:library_submission, assets: input_plate_2.wells, request_types: submission_request_types) target_submission_3 = - create :library_submission, assets: input_plate_3.wells, request_types: submission_request_types + create(:library_submission, assets: input_plate_3.wells, request_types: submission_request_types) target_submission_4 = - create :library_submission, assets: input_plate_4.wells, request_types: submission_request_types - decoy_submission = create :library_submission, assets: input_plate_1.wells, request_types: submission_request_types + create(:library_submission, assets: input_plate_4.wells, request_types: submission_request_types) + decoy_submission = create(:library_submission, assets: input_plate_1.wells, request_types: submission_request_types) input_plate_1.wells.each do |well| next if well.aliquots.empty? - create :library_request, - request_type: library_request_type, - asset: well, - submission: target_submission_1, - state: 'started' - create :library_request, - request_type: library_request_type, - asset: well, - submission: decoy_submission, - state: 'started' + create( + :library_request, + request_type: library_request_type, + asset: well, + submission: target_submission_1, + state: 'started' + ) + create( + :library_request, + request_type: library_request_type, + asset: well, + submission: decoy_submission, + state: 'started' + ) end input_plate_2.wells.each do |well| next if well.aliquots.empty? - create :library_request, - request_type: library_request_type, - asset: well, - submission: target_submission_2, - state: 'started' + create( + :library_request, + request_type: library_request_type, + asset: well, + submission: target_submission_2, + state: 'started' + ) end input_plate_3.wells.each do |well| next if well.aliquots.empty? - create :library_request, - request_type: library_request_type, - asset: well, - submission: target_submission_3, - state: 'started' + create( + :library_request, + request_type: library_request_type, + asset: well, + submission: target_submission_3, + state: 'started' + ) end input_plate_4.wells.each do |well| next if well.aliquots.empty? - create :library_request, - request_type: library_request_type, - asset: well, - submission: target_submission_4, - state: 'started' + create( + :library_request, + request_type: library_request_type, + asset: well, + submission: target_submission_4, + state: 'started' + ) end # The decoy submission represents a submission which we don't care about # The target plate is the downstream plate we are going to be passing. target_plate_1 = - create :target_plate, parent: input_plate_1, well_count: tested_wells, submission: target_submission_1 + create(:target_plate, parent: input_plate_1, well_count: tested_wells, submission: target_submission_1) target_plate_2 = - create :target_plate, parent: input_plate_2, well_count: tested_wells, submission: target_submission_2 + create(:target_plate, parent: input_plate_2, well_count: tested_wells, submission: target_submission_2) target_plate_3 = - create :target_plate, parent: input_plate_3, well_count: tested_wells, submission: target_submission_3 + create(:target_plate, parent: input_plate_3, well_count: tested_wells, submission: target_submission_3) target_plate_4 = - create :target_plate, parent: input_plate_4, well_count: tested_wells, submission: target_submission_4 + create(:target_plate, parent: input_plate_4, well_count: tested_wells, submission: target_submission_4) # Build the tube graphs - tube_1_2 = create :new_stock_multiplexed_library_tube, parents: [target_plate_1, target_plate_2] + tube_1_2 = create(:new_stock_multiplexed_library_tube, parents: [target_plate_1, target_plate_2]) [target_plate_1, target_plate_2].flat_map(&:wells) - .each { |well| create :transfer_request, asset: well, target_asset: tube_1_2 } + .each { |well| create(:transfer_request, asset: well, target_asset: tube_1_2) } - tube_3 = create :new_stock_multiplexed_library_tube, parents: [target_plate_3] + tube_3 = create(:new_stock_multiplexed_library_tube, parents: [target_plate_3]) - target_plate_3.wells.each { |well| create :transfer_request, asset: well, target_asset: tube_3 } + target_plate_3.wells.each { |well| create(:transfer_request, asset: well, target_asset: tube_3) } - tube_4 = create :new_stock_multiplexed_library_tube, parents: [target_plate_4] + tube_4 = create(:new_stock_multiplexed_library_tube, parents: [target_plate_4]) - target_plate_4.wells.each { |well| create :transfer_request, asset: well, target_asset: tube_4 } + target_plate_4.wells.each { |well| create(:transfer_request, asset: well, target_asset: tube_4) } thirds = [tube_1_2, tube_3, tube_4].map do |start| - second = create :new_stock_multiplexed_library_tube # , parents: [start] - create :transfer_request, asset: start, target_asset: second - third = create :new_stock_multiplexed_library_tube # , parents: [second] - create :transfer_request, asset: second, target_asset: third + second = create(:new_stock_multiplexed_library_tube) # , parents: [start] + create(:transfer_request, asset: start, target_asset: second) + third = create(:new_stock_multiplexed_library_tube) # , parents: [second] + create(:transfer_request, asset: second, target_asset: third) third end - @target_tube = create :multiplexed_library_tube, parents: thirds - thirds.each { |third| create :transfer_request, asset: third, target_asset: @target_tube } + @target_tube = create(:multiplexed_library_tube, parents: thirds) + thirds.each { |third| create(:transfer_request, asset: third, target_asset: @target_tube) } end # rubocop:enable Metrics/AbcSize, Metrics/PerceivedComplexity diff --git a/test/performance/work_completions_test.rb b/test/performance/work_completions_test.rb index d6d54f4c8f..b13eab53b7 100644 --- a/test/performance/work_completions_test.rb +++ b/test/performance/work_completions_test.rb @@ -7,36 +7,40 @@ class WorkCompletionsTest < ActionDispatch::PerformanceTest self.profile_options = { runs: 1, metrics: %i[wall_time memory], formats: [:flat] } def setup # rubocop:todo Metrics/AbcSize, Metrics/MethodLength - @user = create :user + @user = create(:user) tested_wells = 96 - input_plate = create :input_plate, well_count: tested_wells - library_request_type = create :library_request_type - multiplex_request_type = create :multiplex_request_type + input_plate = create(:input_plate, well_count: tested_wells) + library_request_type = create(:library_request_type) + multiplex_request_type = create(:multiplex_request_type) submission_request_types = [library_request_type, multiplex_request_type] - @target_submission = create :library_submission, assets: input_plate.wells, request_types: submission_request_types - decoy_submission = create :library_submission, assets: input_plate.wells, request_types: submission_request_types + @target_submission = create(:library_submission, assets: input_plate.wells, request_types: submission_request_types) + decoy_submission = create(:library_submission, assets: input_plate.wells, request_types: submission_request_types) # The decoy submission represents a submission which we don't care about # The target plate is the downstream plate we are going to be passing. - @target_plate = create :target_plate, parent: input_plate, well_count: tested_wells + @target_plate = create(:target_plate, parent: input_plate, well_count: tested_wells) input_plate.wells.each do |well| - create :library_request, - request_type: library_request_type, - asset: well, - submission: @target_submission, - state: 'started' - create :library_request, - request_type: library_request_type, - asset: well, - submission: decoy_submission, - state: 'started' + create( + :library_request, + request_type: library_request_type, + asset: well, + submission: @target_submission, + state: 'started' + ) + create( + :library_request, + request_type: library_request_type, + asset: well, + submission: decoy_submission, + state: 'started' + ) end submission_request_types[1..].each do |downstream_type| input_plate.wells.count.times do - create :multiplex_request, request_type: downstream_type, submission: @target_submission - create :multiplex_request, request_type: downstream_type, submission: decoy_submission + create(:multiplex_request, request_type: downstream_type, submission: @target_submission) + create(:multiplex_request, request_type: downstream_type, submission: decoy_submission) end end end diff --git a/test/shoulda_macros/sanger_macros.rb b/test/shoulda_macros/sanger_macros.rb index 8bbca6d698..95f4950928 100644 --- a/test/shoulda_macros/sanger_macros.rb +++ b/test/shoulda_macros/sanger_macros.rb @@ -23,7 +23,7 @@ def should_require_login(*actions) # rubocop:todo Metrics/CyclomaticComplexity, setup do session[:user] = create(:user) begin - get action, params: params + get(action, params:) rescue AbstractController::ActionNotFound flunk "Testing for an unknown action: #{action}" rescue ActiveRecord::RecordNotFound @@ -46,14 +46,14 @@ def should_require_login(*actions) # rubocop:todo Metrics/CyclomaticComplexity, session[:user] = nil if params[:resource].present? resource = params.delete(:resource) - params['id'] = (create resource).id + params['id'] = create(resource).id end if params[:parent].present? parent_resource = params.delete(:parent) - params["#{parent_resource}_id"] = (create parent_resource).id + params["#{parent_resource}_id"] = create(parent_resource).id end begin - get action, params: params + get(action, params:) rescue AbstractController::ActionNotFound flunk "Testing for an unknown action: #{action}" end diff --git a/test/shoulda_macros/sanger_macros/resource_test.rb b/test/shoulda_macros/sanger_macros/resource_test.rb index 9e33d2163e..9dfb0d3865 100644 --- a/test/shoulda_macros/sanger_macros/resource_test.rb +++ b/test/shoulda_macros/sanger_macros/resource_test.rb @@ -50,7 +50,7 @@ def resource_test(resource_name, kwords) index_url = "#{parent_resource}_#{resource_name.to_s.pluralize}_path(@#{parent_resource})" setup do - parent = create parent_resource + parent = create(parent_resource) @factory_options[parent_resource.to_sym] = parent @input_params["#{parent_resource}_id"] = parent.id end @@ -96,7 +96,7 @@ def resource_test(resource_name, kwords) if actions.include?('show') context "should show #{resource_name}" do setup do - @object = create resource_name, @factory_options + @object = create(resource_name, @factory_options) @input_params[:id] = @object.id get :show, params: @input_params end @@ -107,7 +107,7 @@ def resource_test(resource_name, kwords) if actions.include?('edit') context 'should get edit' do setup do - @object = create resource_name, @factory_options + @object = create(resource_name, @factory_options) @input_params[:id] = @object.id get :edit, params: @input_params end @@ -118,7 +118,7 @@ def resource_test(resource_name, kwords) if actions.include?('update') context 'should update' do setup do - @object = create resource_name + @object = create(resource_name) @input_params[resource_name] = @create_options @input_params[:id] = @object.id put :update, params: @input_params @@ -130,7 +130,7 @@ def resource_test(resource_name, kwords) if actions.include?('destroy') context 'should destroy' do setup do - @object = create resource_name + @object = create(resource_name) @input_params[:id] = @object.id delete :destroy, params: @input_params end @@ -141,7 +141,7 @@ def resource_test(resource_name, kwords) context 'should not have untested action' do untested_actions.each do |action| should action.to_s do - @object = create resource_name + @object = create(resource_name) @input_params[:id] = @object.id assert_raise AbstractController::ActionNotFound do get action, params: @input_params @@ -154,7 +154,7 @@ def resource_test(resource_name, kwords) if other_actions.include?('status') context 'should show status' do setup do - @object = create resource_name + @object = create(resource_name) get :status, params: { id: @object.id } end should respond_with :success @@ -166,7 +166,7 @@ def resource_test(resource_name, kwords) if actions.include?('index') context 'when using XML to access a list ' do setup do - @object = create resource_name, @factory_options + @object = create(resource_name, @factory_options) @request.accept = 'application/xml' get :index, params: @input_params end @@ -182,7 +182,7 @@ def resource_test(resource_name, kwords) context 'when using XML to access a single object' do setup do @request.accept = 'application/xml' - @object = create resource_name, @factory_options + @object = create(resource_name, @factory_options) @input_params[:id] = @object.id get :show, params: @input_params end @@ -197,7 +197,7 @@ def resource_test(resource_name, kwords) if actions.include?('index') context 'when using JSON to access a list ' do setup do - @object = create resource_name, @factory_options + @object = create(resource_name, @factory_options) @request.accept = 'text/x-json' get :index, params: @input_params end @@ -210,7 +210,7 @@ def resource_test(resource_name, kwords) if actions.include?('show') context 'when using JSON to access a single object' do setup do - @object = create resource_name, @factory_options + @object = create(resource_name, @factory_options) @request.accept = 'text/x-json' @input_params[:id] = @object.id get :show, params: @input_params diff --git a/test/unit/accession_service_test.rb b/test/unit/accession_service_test.rb index d6139559fa..aaacd0963b 100644 --- a/test/unit/accession_service_test.rb +++ b/test/unit/accession_service_test.rb @@ -14,8 +14,8 @@ def assert_tag(tag_label, value) # temporary test for hotfix context 'A sample with a strain' do setup do - @study = create :open_study, accession_number: 'accss' - @sample = create :sample, studies: [@study] + @study = create(:open_study, accession_number: 'accss') + @sample = create(:sample, studies: [@study]) @sample.sample_metadata.sample_strain_att = 'my strain' end @@ -26,8 +26,8 @@ def assert_tag(tag_label, value) context 'A sample with a gender' do setup do - @study = create :managed_study, accession_number: 'accss' - @sample = create :sample, studies: [@study] + @study = create(:managed_study, accession_number: 'accss') + @sample = create(:sample, studies: [@study]) @sample.sample_metadata.gender = 'male' end @@ -38,8 +38,8 @@ def assert_tag(tag_label, value) context 'A sample with a donor_id' do setup do - @study = create :managed_study, accession_number: 'accss' - @sample = create :sample, studies: [@study] + @study = create(:managed_study, accession_number: 'accss') + @sample = create(:sample, studies: [@study]) @sample.sample_metadata.donor_id = '123456789' end @@ -54,9 +54,9 @@ def assert_tag(tag_label, value) context 'A sample with a country_of_origin' do setup do - @country = create :insdc_country, name: 'Freedonia' - @study = create :managed_study, accession_number: 'accss' - @sample = create :sample, studies: [@study] + @country = create(:insdc_country, name: 'Freedonia') + @study = create(:managed_study, accession_number: 'accss') + @sample = create(:sample, studies: [@study]) end context 'with unexistent country' do @@ -96,8 +96,8 @@ def assert_tag(tag_label, value) context 'A sample with a collection date' do setup do - @study = create :managed_study, accession_number: 'accss' - @sample = create :sample, studies: [@study] + @study = create(:managed_study, accession_number: 'accss') + @sample = create(:sample, studies: [@study]) end context 'with unexistent date_of_sample_collection' do diff --git a/test/unit/aliquot_indexer_test.rb b/test/unit/aliquot_indexer_test.rb index 72b412faa9..f368142bba 100644 --- a/test/unit/aliquot_indexer_test.rb +++ b/test/unit/aliquot_indexer_test.rb @@ -7,10 +7,10 @@ class AliquotIndexerTest < ActiveSupport::TestCase context 'which are dual indexed' do setup do @pre_count = AliquotIndex.count - @lane = create :lane - @tags = [1, 8, 2, 4].map { |map_id| create :tag, map_id: map_id } - @tag2s = [1, 2].map { |map_id| create :tag, map_id: map_id } * 2 - @aliquots = Array.new(4) { |i| create :aliquot, receptacle: @lane, tag: @tags[i], tag2: @tag2s[i] } + @lane = create(:lane) + @tags = [1, 8, 2, 4].map { |map_id| create(:tag, map_id:) } + @tag2s = [1, 2].map { |map_id| create(:tag, map_id:) } * 2 + @aliquots = Array.new(4) { |i| create(:aliquot, receptacle: @lane, tag: @tags[i], tag2: @tag2s[i]) } @aliquot_index = [1, 4, 2, 3] end @@ -35,7 +35,7 @@ class AliquotIndexerTest < ActiveSupport::TestCase context 'when phix is added' do setup do - @phix = create :spiked_buffer, aliquot_attributes: { tag: @tags[2], tag2: nil } + @phix = create(:spiked_buffer, aliquot_attributes: { tag: @tags[2], tag2: nil }) @lane.labware.parents << @phix @aliquot_index = [1, 5, 3, 4] end @@ -63,9 +63,9 @@ class AliquotIndexerTest < ActiveSupport::TestCase context 'which are single indexed' do setup do @pre_count = AliquotIndex.count - @lane = create :lane - @tags = [1, 8, 2, 4].map { |map_id| create :tag, map_id: map_id } - @aliquots = Array.new(4) { |i| create :aliquot, receptacle: @lane, tag: @tags[i], tag2_id: -1 } + @lane = create(:lane) + @tags = [1, 8, 2, 4].map { |map_id| create(:tag, map_id:) } + @aliquots = Array.new(4) { |i| create(:aliquot, receptacle: @lane, tag: @tags[i], tag2_id: -1) } @aliquot_index = [1, 4, 2, 3] end @@ -90,7 +90,7 @@ class AliquotIndexerTest < ActiveSupport::TestCase context 'when phix is added' do setup do - @phix = create :spiked_buffer, aliquot_attributes: { tag: @tags[2], tag2: nil } + @phix = create(:spiked_buffer, aliquot_attributes: { tag: @tags[2], tag2: nil }) @lane.labware.parents << @phix @aliquot_index = [1, 5, 3, 4] end @@ -118,9 +118,9 @@ class AliquotIndexerTest < ActiveSupport::TestCase context 'which are single indexed with i5 (tag2) tags' do setup do @pre_count = AliquotIndex.count - @lane = create :lane - @tags = [1, 8, 2, 4].map { |map_id| create :tag, map_id: map_id } - @aliquots = Array.new(4) { |i| create :aliquot, receptacle: @lane, tag_id: -1, tag2: @tags[i] } + @lane = create(:lane) + @tags = [1, 8, 2, 4].map { |map_id| create(:tag, map_id:) } + @aliquots = Array.new(4) { |i| create(:aliquot, receptacle: @lane, tag_id: -1, tag2: @tags[i]) } @aliquot_index = [1, 4, 2, 3] end @@ -145,7 +145,7 @@ class AliquotIndexerTest < ActiveSupport::TestCase context 'when phix is added' do setup do - @phix = create :spiked_buffer, aliquot_attributes: { tag: @tags[2], tag2: nil } + @phix = create(:spiked_buffer, aliquot_attributes: { tag: @tags[2], tag2: nil }) @lane.labware.parents << @phix @aliquot_index = [1, 5, 3, 4] end diff --git a/test/unit/aliquot_receptacle_test.rb b/test/unit/aliquot_receptacle_test.rb index 0a87bb4a0b..44d1e667e5 100644 --- a/test/unit/aliquot_receptacle_test.rb +++ b/test/unit/aliquot_receptacle_test.rb @@ -4,7 +4,7 @@ class ReceptacleTest < ActiveSupport::TestCase context 'Receptacle' do - setup { @receptacle = create :receptacle } + setup { @receptacle = create(:receptacle) } [ ['Untagged', [:untagged_aliquot]], diff --git a/test/unit/asset_group_test.rb b/test/unit/asset_group_test.rb index 0ed308bd99..7e72b61b0a 100644 --- a/test/unit/asset_group_test.rb +++ b/test/unit/asset_group_test.rb @@ -16,8 +16,8 @@ class AssetGroupTest < ActiveSupport::TestCase @asset3 = mock('Asset 3') @asset3.stubs(:id).returns(3) @assets = [] - @study = create :study - @asset_group = create :asset_group, study_id: @study.id + @study = create(:study) + @asset_group = create(:asset_group, study_id: @study.id) @asset_group.stubs(:assets).returns([@asset1, @asset2]) end @@ -52,8 +52,8 @@ class AssetGroupTest < ActiveSupport::TestCase @asset2.stubs(:id).returns(2) @asset2.stubs(:sti_type).returns('Well') @assets = [] - @study = create :study - @asset_group = create :asset_group, study_id: @study.id + @study = create(:study) + @asset_group = create(:asset_group, study_id: @study.id) @asset_group.stubs(:assets).returns([@asset1, @asset2]) end @@ -77,8 +77,8 @@ class AssetGroupTest < ActiveSupport::TestCase @asset2.stubs(:id).returns(2) @asset2.stubs(:sti_type).returns('Tube') @assets = [] - @study = create :study - @asset_group = create :asset_group, study_id: @study.id + @study = create(:study) + @asset_group = create(:asset_group, study_id: @study.id) @asset_group.stubs(:assets).returns([@asset1, @asset2]) end @@ -91,17 +91,17 @@ class AssetGroupTest < ActiveSupport::TestCase setup do @ag_count = AssetGroup.count Study.destroy_all - @study = create :study + @study = create(:study) end should 'not allow an AssetGroup to be created without a study' do assert_raises ActiveRecord::RecordInvalid do - @asset_group = create :asset_group, study_id: nil + @asset_group = create(:asset_group, study_id: nil) end end should 'not allow an AssetGroup to be created without a name' do assert_raises ActiveRecord::RecordInvalid do - @asset_group = create :asset_group, name: '', study_id: @study.id + @asset_group = create(:asset_group, name: '', study_id: @study.id) end end @@ -110,14 +110,14 @@ class AssetGroupTest < ActiveSupport::TestCase end should 'only allow a name to be used once' do - create :asset_group, name: 'Another-Name', study_id: @study.id + create(:asset_group, name: 'Another-Name', study_id: @study.id) assert_raises ActiveRecord::RecordInvalid do - create :asset_group, name: 'Another-Name', study_id: @study.id + create(:asset_group, name: 'Another-Name', study_id: @study.id) end end context '#all_samples_have_accession_numbers?' do - setup { @asset_group = build :asset_group } + setup { @asset_group = build(:asset_group) } context 'where all samples' do setup do 2.times do |_i| @@ -164,7 +164,7 @@ class AssetGroupTest < ActiveSupport::TestCase end context '#all_samples_have_accession_numbers? On saved asset groups' do - setup { @asset_group = create :asset_group } + setup { @asset_group = create(:asset_group) } context 'where all samples' do setup do 2.times do |_i| diff --git a/test/unit/asset_link_test.rb b/test/unit/asset_link_test.rb index 263c7b53ba..55019d3923 100644 --- a/test/unit/asset_link_test.rb +++ b/test/unit/asset_link_test.rb @@ -5,8 +5,8 @@ class AssetLinkTest < ActiveSupport::TestCase context 'AssetLink::Job' do setup do - @source_tube = create :tube - @destination_tube = create :tube + @source_tube = create(:tube) + @destination_tube = create(:tube) @job_count = Delayed::Job.count AssetLink::Job.create(@source_tube, [@destination_tube]) end diff --git a/test/unit/barcode_printer_test.rb b/test/unit/barcode_printer_test.rb index 40669baf18..e6c6f1b46c 100644 --- a/test/unit/barcode_printer_test.rb +++ b/test/unit/barcode_printer_test.rb @@ -6,10 +6,10 @@ class BarcodePrinterTest < ActiveSupport::TestCase attr_reader :barcode_printer, :printer_for_384_wells_plate def setup - @barcode_printer = create :barcode_printer, name: 'test_printer' + @barcode_printer = create(:barcode_printer, name: 'test_printer') printer384 = BarcodePrinterType.find_by(name: '384 Well Plate') || create(:barcode_printer_type, name: '384 Well Plate') - @printer_for_384_wells_plate = create :barcode_printer, barcode_printer_type: printer384 + @printer_for_384_wells_plate = create(:barcode_printer, barcode_printer_type: printer384) end test 'should know if it can print on plates with 384 wells' do @@ -36,7 +36,7 @@ def setup accept: 'application/vnd.api+json' ) .returns(201) - create :barcode_printer, name: 'test_printer' + create(:barcode_printer, name: 'test_printer') configatron.register_printers_automatically = false end end diff --git a/test/unit/batch_test.rb b/test/unit/batch_test.rb index 2ed51a8523..fceffa4aa4 100644 --- a/test/unit/batch_test.rb +++ b/test/unit/batch_test.rb @@ -5,7 +5,7 @@ class BatchTest < ActiveSupport::TestCase context 'A batch' do context 'on its own' do - setup { @batch = build :batch } + setup { @batch = build(:batch) } should 'have begin in pending then change to started' do assert_equal @batch.state, 'pending' @@ -18,11 +18,11 @@ class BatchTest < ActiveSupport::TestCase context 'modifying request positions within a batch' do setup do - @pipeline = create :pipeline + @pipeline = create(:pipeline) # Weirdly, this is actually FASTER than factories by a substantial amount @requests = Array.new(10) { @pipeline.request_types.last.create! } - @batch = create :batch, requests: @requests, pipeline: @pipeline + @batch = create(:batch, requests: @requests, pipeline: @pipeline) end context '#assign_positions_to_requests!' do @@ -49,11 +49,11 @@ class BatchTest < ActiveSupport::TestCase context 'when batch is created' do setup do - @pipeline = create :pipeline - @request1 = create :request, request_type: @pipeline.request_types.first - @request2 = create :request, request_type: @pipeline.request_types.first + @pipeline = create(:pipeline) + @request1 = create(:request, request_type: @pipeline.request_types.first) + @request2 = create(:request, request_type: @pipeline.request_types.first) - @batch = create :batch, requests: [@request1, @request2], pipeline: @pipeline + @batch = create(:batch, requests: [@request1, @request2], pipeline: @pipeline) end should 'be able to call start_requests' do @@ -87,7 +87,7 @@ class BatchTest < ActiveSupport::TestCase context 'batch #has_event(event_name)' do setup do - @batch = create :batch + @batch = create(:batch) @batch.start!(create(:user)) @lab_event = LabEvent.new @@ -115,9 +115,9 @@ class BatchTest < ActiveSupport::TestCase context '#requests_by_study' do setup do - @pipeline = create :pipeline, locale: 'Internal' - @batch = create :batch, pipeline: @pipeline - @study1 = create :study + @pipeline = create(:pipeline, locale: 'Internal') + @batch = create(:batch, pipeline: @pipeline) + @study1 = create(:study) end context 'with no requests' do @@ -128,8 +128,8 @@ class BatchTest < ActiveSupport::TestCase context 'with 1 request' do setup do - @study2 = create :study - @request1 = create :request, request_type: @pipeline.request_types.last, study: @study1, batch: @batch + @study2 = create(:study) + @request1 = create(:request, request_type: @pipeline.request_types.last, study: @study1, batch: @batch) end should 'return correct studies' do @@ -140,10 +140,10 @@ class BatchTest < ActiveSupport::TestCase context 'with 2 requests from different studies' do setup do - @study2 = create :study - @study3 = create :study - @request1 = create :request, request_type: @pipeline.request_types.last, study: @study1 - @request2 = create :request, request_type: @pipeline.request_types.last, study: @study2 + @study2 = create(:study) + @study3 = create(:study) + @request1 = create(:request, request_type: @pipeline.request_types.last, study: @study1) + @request2 = create(:request, request_type: @pipeline.request_types.last, study: @study2) @batch.requests << @request1 << @request2 end @@ -157,9 +157,9 @@ class BatchTest < ActiveSupport::TestCase context '#plate_ids_in_study' do setup do - @pipeline = create :pipeline - @batch = create :batch, pipeline: @pipeline - @study1 = create :study + @pipeline = create(:pipeline) + @batch = create(:batch, pipeline: @pipeline) + @study1 = create(:study) end context 'with no requests' do @@ -170,12 +170,12 @@ class BatchTest < ActiveSupport::TestCase context 'with 2 request on a different plates' do setup do - @study2 = create :study - @plate1 = create :plate - @well1 = create :well, plate: @plate1 + @study2 = create(:study) + @plate1 = create(:plate) + @well1 = create(:well, plate: @plate1) - @plate2 = create :plate - @well2 = create :well, plate: @plate2 + @plate2 = create(:plate) + @well2 = create(:well, plate: @plate2) @batch.requests = [ @pipeline.request_types.last.create!(study: @study1, asset: @well1), @@ -203,7 +203,7 @@ class BatchTest < ActiveSupport::TestCase should_have_instance_methods :assigned_user, :start, :fail, :workflow, :started?, :released?, :qc_state - setup { @pipeline = create :sequencing_pipeline, name: 'Pipeline for BatchTest' } + setup { @pipeline = create(:sequencing_pipeline, name: 'Pipeline for BatchTest') } context 'create requests' do setup do @@ -237,7 +237,7 @@ class BatchTest < ActiveSupport::TestCase # send_fail_event will be used once since only one request is not a resource /@request1 # EventSender.expects(:send_fail_event).returns(true).times(1) EventSender.stubs(:send_fail_event).returns(true) - @control = create :sample_tube, resource: true + @control = create(:sample_tube, resource: true) @batch = @pipeline.batches.create! @request1, @request2 = @@ -335,8 +335,8 @@ class BatchTest < ActiveSupport::TestCase context '#public methods' do setup do - @asset1 = create :sample_tube, barcode: '123456' - @asset2 = create :sample_tube, barcode: '654321' + @asset1 = create(:sample_tube, barcode: '123456') + @asset2 = create(:sample_tube, barcode: '654321') @request1 = @pipeline.request_types.last.create!(asset: @asset1) @request2 = @pipeline.request_types.last.create!(asset: @asset2) @@ -371,14 +371,14 @@ class BatchTest < ActiveSupport::TestCase end should 'return user login' do - @user = create :user + @user = create(:user) @batch.assignee_id = @user.id assert 'lg1', @batch.assigned_user end context 'with control' do setup do - @control = create :sample_tube, resource: true + @control = create(:sample_tube, resource: true) @request = @pipeline.request_types.last.create!(asset: @control) @batch.batch_requests.create!(request: @request, position: 3) end @@ -434,7 +434,7 @@ class BatchTest < ActiveSupport::TestCase context '#reset!' do context 'once started' do - setup { @batch = create :batch, pipeline: @pipeline, state: 'started' } + setup { @batch = create(:batch, pipeline: @pipeline, state: 'started') } should 'raise an exception' do assert_raise AASM::InvalidTransition do @@ -449,10 +449,10 @@ class BatchTest < ActiveSupport::TestCase }.each do |pipeline_type, request_factory| context "of a #{pipeline_type}" do setup do - @pipeline = create pipeline_type - @batch = create :batch, pipeline: @pipeline - @pending_request = create request_factory, request_type: @pipeline.request_types.last - @pending_request_2 = create request_factory, request_type: @pipeline.request_types.last + @pipeline = create(pipeline_type) + @batch = create(:batch, pipeline: @pipeline) + @pending_request = create(request_factory, request_type: @pipeline.request_types.last) + @pending_request_2 = create(request_factory, request_type: @pipeline.request_types.last) @batch.requests << @pending_request << @pending_request_2 end @@ -483,8 +483,8 @@ class BatchTest < ActiveSupport::TestCase context '#qc_previous_state!' do setup do - @user = create :user - @batch = create :batch, pipeline: @pipeline + @user = create(:user) + @batch = create(:batch, pipeline: @pipeline) @batch.update!(qc_state: 'qc_completed') end should 'move batch to previous qc state' do @@ -503,16 +503,16 @@ class BatchTest < ActiveSupport::TestCase context "when swapping #{left_position} and #{right_position}" do setup do # Create a batch with a couple of requests positioned appropriately - @left_batch = create :batch, pipeline: @pipeline - @original_left_request = create :batch_request, batch_id: @left_batch.id, position: left_position - create :batch_request, batch_id: @left_batch.id, position: 1 + @left_batch = create(:batch, pipeline: @pipeline) + @original_left_request = create(:batch_request, batch_id: @left_batch.id, position: left_position) + create(:batch_request, batch_id: @left_batch.id, position: 1) # Now create another batch that we'll swap the requests between - @right_batch = create :batch, pipeline: @pipeline - @original_right_request = create :batch_request, batch_id: @right_batch.id, position: right_position - create :batch_request, batch_id: @right_batch.id, position: 2 + @right_batch = create(:batch, pipeline: @pipeline) + @original_right_request = create(:batch_request, batch_id: @right_batch.id, position: right_position) + create(:batch_request, batch_id: @right_batch.id, position: 2) - @user = create :user + @user = create(:user) end should 'swap lanes given 2 batches and swap requests.' do @@ -546,12 +546,12 @@ class BatchTest < ActiveSupport::TestCase context '#detach_request' do setup do - @library_prep_pipeline = create :pipeline, name: 'Library Prep Pipeline' - @lib_prep_batch = create :batch, pipeline: @library_prep_pipeline - @sample_tube = create :sample_tube, name: 'sample tube 1' - @library_tube = create :library_tube, name: 'lib tube 1' - @lib_prep_request = create :library_request, state: 'started', asset: @sample_tube, target_asset: @library_tube - @pe_seq_request = create :sequencing_request, state: 'pending', asset: @library_tube + @library_prep_pipeline = create(:pipeline, name: 'Library Prep Pipeline') + @lib_prep_batch = create(:batch, pipeline: @library_prep_pipeline) + @sample_tube = create(:sample_tube, name: 'sample tube 1') + @library_tube = create(:library_tube, name: 'lib tube 1') + @lib_prep_request = create(:library_request, state: 'started', asset: @sample_tube, target_asset: @library_tube) + @pe_seq_request = create(:sequencing_request, state: 'pending', asset: @library_tube) @lib_prep_batch.requests << @lib_prep_request end @@ -593,23 +593,23 @@ class BatchTest < ActiveSupport::TestCase context '#last_completed_task' do setup do - @library_prep_pipeline = create :pipeline, name: 'Library Prep Pipeline' - @task1 = create :task, workflow: @library_prep_pipeline.workflow, name: 'Task 1', sorted: 0 - @task2 = create :task, workflow: @library_prep_pipeline.workflow, name: 'Task 2', sorted: 1 - @task3 = create :task, workflow: @library_prep_pipeline.workflow, name: 'Task 3', sorted: 2 + @library_prep_pipeline = create(:pipeline, name: 'Library Prep Pipeline') + @task1 = create(:task, workflow: @library_prep_pipeline.workflow, name: 'Task 1', sorted: 0) + @task2 = create(:task, workflow: @library_prep_pipeline.workflow, name: 'Task 2', sorted: 1) + @task3 = create(:task, workflow: @library_prep_pipeline.workflow, name: 'Task 3', sorted: 2) - @batch = create :batch, pipeline: @library_prep_pipeline, state: 'started' + @batch = create(:batch, pipeline: @library_prep_pipeline, state: 'started') @batch.requests << @library_prep_pipeline.request_types.last.create!(state: 'started') # NO idea why descriptors are added twice here, or why the descriptors # implementation appears to be so complicated. I've converted this from # mocks to use factories instead, I'm keeping the duplicate tasks # until I can work out why they were added. - @event1 = create :lab_event, description: 'Complete', batch: @batch + @event1 = create(:lab_event, description: 'Complete', batch: @batch) @event1.add_new_descriptor 'task_id', @task1.id.to_s @event1.add_new_descriptor 'task_id', @task1.id.to_s - @event2 = create :lab_event, description: 'Complete', batch: @batch + @event2 = create(:lab_event, description: 'Complete', batch: @batch) @event2.add_new_descriptor 'task_id', @task2.id.to_s @event2.add_new_descriptor 'task_id', @task2.id.to_s @@ -639,11 +639,11 @@ class BatchTest < ActiveSupport::TestCase # JG: The QC state machine on batch is near non-existent, and all events # just push the batch into the next state. Here we advance the qc_state # to try and model what appears to be the intended behaviour. - @pipeline = create :sequencing_pipeline - @batch = create :batch, pipeline: @pipeline + @pipeline = create(:sequencing_pipeline) + @batch = create(:batch, pipeline: @pipeline) @batch.update!(qc_state: 'qc_manual_in_progress') @requests = - create_list :sequencing_request_with_assets, 2, state: 'started', request_type: @pipeline.request_types.first + create_list(:sequencing_request_with_assets, 2, state: 'started', request_type: @pipeline.request_types.first) @batch.requests = @requests end @@ -684,14 +684,14 @@ class BatchTest < ActiveSupport::TestCase context 'ready? all requests before creating batch' do setup do - @library_tube = create :library_tube, sample_count: 1 + @library_tube = create(:library_tube, sample_count: 1) @library_creation_request = create(:library_creation_request_for_testing_sequencing_requests, target_asset: @library_tube) - @pipeline = create :sequencing_pipeline + @pipeline = create(:sequencing_pipeline) @library_tube.create_scanned_into_lab_event!(content: '2018-01-01') - @batch = build :batch, pipeline: @pipeline + @batch = build(:batch, pipeline: @pipeline) @request_type = @batch.pipeline.request_types.first @sequencing_request = create(:sequencing_request, asset: @library_tube, request_type: @request_type) @batch.requests << @sequencing_request diff --git a/test/unit/cherrypick_task_test.rb b/test/unit/cherrypick_task_test.rb index de5921fb2f..88d4cc569f 100644 --- a/test/unit/cherrypick_task_test.rb +++ b/test/unit/cherrypick_task_test.rb @@ -48,7 +48,7 @@ def maps_for(num, from = 0, order = 'column') pp.save! end - @task = build :cherrypick_task + @task = build(:cherrypick_task) @robot = mock('robot') @robot.stubs(:max_beds).returns(2) diff --git a/test/unit/custom_metadatum_collection_test.rb b/test/unit/custom_metadatum_collection_test.rb index b05569e424..b9b6dc6507 100644 --- a/test/unit/custom_metadatum_collection_test.rb +++ b/test/unit/custom_metadatum_collection_test.rb @@ -13,13 +13,13 @@ class CustomMetadatumCollectionTest < ActiveSupport::TestCase test 'should be able to create metadata' do custom_metadatum_collection = - create(:custom_metadatum_collection, metadata: ({ 'Key1' => 'Value1', 'Key2' => 'Value2' })) + create(:custom_metadatum_collection, metadata: { 'Key1' => 'Value1', 'Key2' => 'Value2' }) assert_equal 2, custom_metadatum_collection.custom_metadata.length assert_equal 'Key1', custom_metadatum_collection.custom_metadata.first.key end test 'should be able to create metadata and check if it is valid' do - custom_metadatum_collection = build(:custom_metadatum_collection, metadata: ({ 'Key1' => 'Value1', 'Key2' => '' })) + custom_metadatum_collection = build(:custom_metadatum_collection, metadata: { 'Key1' => 'Value1', 'Key2' => '' }) assert_not custom_metadatum_collection.valid? end @@ -31,7 +31,7 @@ class CustomMetadatumCollectionTest < ActiveSupport::TestCase test 'should update metadata' do custom_metadatum_collection = - create(:custom_metadatum_collection, metadata: ({ 'Key1' => 'Value1', 'Key2' => 'Value2' })) + create(:custom_metadatum_collection, metadata: { 'Key1' => 'Value1', 'Key2' => 'Value2' }) custom_metadatum_collection.update(metadata: { 'Key1' => 'New value', 'Key3' => 'Value3' }) assert_equal 2, custom_metadatum_collection.custom_metadata.length assert_equal 'New value', custom_metadatum_collection.custom_metadata.first.value diff --git a/test/unit/data_release_test.rb b/test/unit/data_release_test.rb index 2c0f998930..f1dee7e4af 100644 --- a/test/unit/data_release_test.rb +++ b/test/unit/data_release_test.rb @@ -4,7 +4,7 @@ class DataReleaseTest < ActiveSupport::TestCase context 'A study' do - setup { @study = create :study } + setup { @study = create(:study) } context '#valid_data_release_properties?' do context 'and data_release enforced' do setup do diff --git a/test/unit/event_factory_test.rb b/test/unit/event_factory_test.rb index 3d301a2b6d..a6492c89dc 100644 --- a/test/unit/event_factory_test.rb +++ b/test/unit/event_factory_test.rb @@ -7,13 +7,13 @@ class EventFactoryTest < ActiveSupport::TestCase context 'An EventFactory' do setup do - @user = create :user, login: 'south', email: 'south@example.com' - @bad_user = create :user, login: 'bad_south', email: '' - @project = create :project, name: 'hello world' - role = create :owner_role, authorizable: @project + @user = create(:user, login: 'south', email: 'south@example.com') + @bad_user = create(:user, login: 'bad_south', email: '') + @project = create(:project, name: 'hello world') + role = create(:owner_role, authorizable: @project) role.users << @user << @bad_user - @request_type = create :request_type, key: 'library_creation', name: 'Library creation' - @request = create :request, request_type: @request_type, user: @user, project: @project + @request_type = create(:request_type, key: 'library_creation', name: 'Library creation') + @request = create(:request, request_type: @request_type, user: @user, project: @project) @emails = ActionMailer::Base.deliveries @emails.clear @labware = create(:sample_tube, retention_instruction: 'return_to_customer_after_2_years') @@ -22,8 +22,8 @@ class EventFactoryTest < ActiveSupport::TestCase context '#new_project' do setup do @event_count = Event.count - admin = create :role, name: 'administrator' - user1 = create :user, login: 'abc123' + admin = create(:role, name: 'administrator') + user1 = create(:user, login: 'abc123') user1.roles << admin EventFactory.new_project(@project, @user) end @@ -42,10 +42,10 @@ class EventFactoryTest < ActiveSupport::TestCase context '#project_approved' do setup do @event_count = Event.count - role = create :manager_role, authorizable: @project + role = create(:manager_role, authorizable: @project) role.users << @user - admin = create :role, name: 'administrator' - user1 = create :user, login: 'west' + admin = create(:role, name: 'administrator') + user1 = create(:user, login: 'west') user1.roles << admin EventFactory.project_approved(@project, @user) end @@ -65,17 +65,17 @@ class EventFactoryTest < ActiveSupport::TestCase setup do @event_count = Event.count ::ActionMailer::Base.deliveries = [] - role = create :manager_role, authorizable: @project + role = create(:manager_role, authorizable: @project) role.users << @user - @user1 = create :user, login: 'north' + @user1 = create(:user, login: 'north') @request.user = @user1 - follower = create :role, name: 'follower' - @user2 = create :user, login: 'west' + follower = create(:role, name: 'follower') + @user2 = create(:user, login: 'west') @user2.roles << follower - @study = create :study, user: @user2 + @study = create(:study, user: @user2) @submission = FactoryHelp.submission(project: @project, study: @study, assets: [create(:sample_tube)]) - @request = create :request, study: @study, project: @project, submission: @submission - @user3 = create :user, login: 'east' + @request = create(:request, study: @study, project: @project, submission: @submission) + @user3 = create(:user, login: 'east') message = 'An error has occurred' EventFactory.request_update_note_to_manager(@request, @user3, message) end diff --git a/test/unit/event_test.rb b/test/unit/event_test.rb index 6858b57e80..7e51bc97d9 100644 --- a/test/unit/event_test.rb +++ b/test/unit/event_test.rb @@ -36,8 +36,8 @@ class EventTest < ActiveSupport::TestCase context 'when related to a Request' do setup do - @study = create :study - @request = create :request, study: @study + @study = create(:study) + @request = create(:request, study: @study) @settings = { eventful_id: @request.id, eventful_type: 'Request', @@ -65,8 +65,8 @@ class EventTest < ActiveSupport::TestCase context '#update_request' do setup do - @study = create :study - @request = create :request, study: @study, state: 'started' + @study = create(:study) + @request = create(:request, study: @study, state: 'started') @settings = { eventful_id: @request.id, eventful_type: 'Request', @@ -118,18 +118,18 @@ class EventTest < ActiveSupport::TestCase context 'when created with a' do setup do - @library_creation_request_type = create :request_type, name: 'Library creation', key: 'library_creation' + @library_creation_request_type = create(:request_type, name: 'Library creation', key: 'library_creation') @mx_library_creation_request_type = - create :request_type, name: 'Multiplexed library creation', key: 'multiplexed_library_creation' - @pe_sequencing_request_type = create :request_type, name: 'Paired end sequencing', key: 'paired_end_sequencing' + create(:request_type, name: 'Multiplexed library creation', key: 'multiplexed_library_creation') + @pe_sequencing_request_type = create(:request_type, name: 'Paired end sequencing', key: 'paired_end_sequencing') @control = create(:sample_tube, resource: true) - @library_creation_request = create :request, request_type: @library_creation_request_type - @multiplexed_library_creation_request = create :request, request_type: @mx_library_creation_request_type - @pe_sequencing_request = create :request, request_type: @pe_sequencing_request_type + @library_creation_request = create(:request, request_type: @library_creation_request_type) + @multiplexed_library_creation_request = create(:request, request_type: @mx_library_creation_request_type) + @pe_sequencing_request = create(:request, request_type: @pe_sequencing_request_type) @request_for_control = - create :request, request_type: @pe_sequencing_request_type, asset: @control, state: 'started' + create(:request, request_type: @pe_sequencing_request_type, asset: @control, state: 'started') @requests = [@library_creation_request, @multiplexed_library_creation_request, @pe_sequencing_request] end diff --git a/test/unit/eventful_entry_test.rb b/test/unit/eventful_entry_test.rb index a196821f4a..9e6fe5ce7c 100644 --- a/test/unit/eventful_entry_test.rb +++ b/test/unit/eventful_entry_test.rb @@ -13,8 +13,8 @@ class EventfulEntry < ApplicationRecord class EventfulEntryTest < ActiveSupport::TestCase context 'A model using events' do setup do - @request_type = create :request_type - @study = create :study + @request_type = create(:request_type) + @study = create(:study) @test_subject = EventfulEntry.create(request_type_id: @request_type.id, study_id: @study.id) @event = Event.new(eventful_id: @test_subject.id, eventful_type: @test_subject.class.to_s, family: 'Billing') diff --git a/test/unit/flexible_submission_test.rb b/test/unit/flexible_submission_test.rb index e8e0e98e62..c5a127aae8 100644 --- a/test/unit/flexible_submission_test.rb +++ b/test/unit/flexible_submission_test.rb @@ -6,7 +6,7 @@ class FlexibleSubmissionTest < ActiveSupport::TestCase context 'FlexibleSubmission' do setup do @assets = create(:two_column_plate).wells.to_a - @pooling = create :pooling_method + @pooling = create(:pooling_method) end should belong_to :study @@ -14,13 +14,13 @@ class FlexibleSubmissionTest < ActiveSupport::TestCase context 'build (Submission factory)' do setup do - @study = create :study - @project = create :project - @user = create :user + @study = create(:study) + @project = create(:project) + @user = create(:user) @library_creation_request_type = - create :well_request_type, target_purpose: nil, for_multiplexing: true, pooling_method: @pooling - @sequencing_request_type = create :sequencing_request_type + create(:well_request_type, target_purpose: nil, for_multiplexing: true, pooling_method: @pooling) + @sequencing_request_type = create(:sequencing_request_type) @request_type_ids = [@library_creation_request_type.id, @sequencing_request_type.id] @@ -66,12 +66,12 @@ class FlexibleSubmissionTest < ActiveSupport::TestCase context 'with qc_criteria' do setup do - @our_product_criteria = create :product_criteria - @current_report = create :qc_report, product_criteria: @our_product_criteria - @stock_well = create :well + @our_product_criteria = create(:product_criteria) + @current_report = create(:qc_report, product_criteria: @our_product_criteria) + @stock_well = create(:well) @metric = - create :qc_metric, asset: @stock_well, qc_report: @current_report, qc_decision: 'failed', proceed: true + create(:qc_metric, asset: @stock_well, qc_report: @current_report, qc_decision: 'failed', proceed: true) @assets.each do |qced_well| qced_well.stock_wells.attach!([@stock_well]) @@ -109,8 +109,8 @@ class FlexibleSubmissionTest < ActiveSupport::TestCase context 'cross study/project submissions' do setup do - @study_b = create :study - @project_b = create :project + @study_b = create(:study) + @project_b = create(:project) @request_count = Request.count end @@ -178,7 +178,7 @@ class FlexibleSubmissionTest < ActiveSupport::TestCase context 'On pooled assets' do setup do @request_count = Request.count - @pooled = create :cross_pooled_well + @pooled = create(:cross_pooled_well) @sub = create( :flexible_submission, @@ -205,13 +205,13 @@ class FlexibleSubmissionTest < ActiveSupport::TestCase context 'with target asset creation' do setup do - @study = create :study - @project = create :project - @user = create :user - mx_purpose = create :mx_tube_purpose + @study = create(:study) + @project = create(:project) + @user = create(:user) + mx_purpose = create(:mx_tube_purpose) @library_creation_request_type = - create :well_request_type, for_multiplexing: true, target_purpose: mx_purpose, pooling_method: @pooling - @sequencing_request_type = create :sequencing_request_type + create(:well_request_type, for_multiplexing: true, target_purpose: mx_purpose, pooling_method: @pooling) + @sequencing_request_type = create(:sequencing_request_type) @request_type_ids = [@library_creation_request_type.id, @sequencing_request_type.id] @@ -275,20 +275,22 @@ class FlexibleSubmissionTest < ActiveSupport::TestCase context 'process with a multiplier for request type' do setup do - @study = create :study - @project = create :project - @user = create :user + @study = create(:study) + @project = create(:project) + @user = create(:user) - @ux_request_type = create :well_request_type, target_purpose: nil, for_multiplexing: false + @ux_request_type = create(:well_request_type, target_purpose: nil, for_multiplexing: false) @mx_request_type = - create :well_request_type, target_purpose: nil, for_multiplexing: true, pooling_method: @pooling + create(:well_request_type, target_purpose: nil, for_multiplexing: true, pooling_method: @pooling) @pe_request_type = - create :request_type, - asset_type: 'LibraryTube', - initial_state: 'pending', - name: 'PE sequencing', - order: 2, - key: 'pe_sequencing' + create( + :request_type, + asset_type: 'LibraryTube', + initial_state: 'pending', + name: 'PE sequencing', + order: 2, + key: 'pe_sequencing' + ) @request_type_ids = [@mx_request_type.id, @pe_request_type.id] @@ -338,20 +340,22 @@ class FlexibleSubmissionTest < ActiveSupport::TestCase context 'correctly calculate multipliers' do setup do - @study = create :study - @project = create :project - @user = create :user + @study = create(:study) + @project = create(:project) + @user = create(:user) - @ux_request_type = create :well_request_type, target_purpose: nil, for_multiplexing: false + @ux_request_type = create(:well_request_type, target_purpose: nil, for_multiplexing: false) @mx_request_type = - create :well_request_type, target_purpose: nil, for_multiplexing: true, pooling_method: @pooling + create(:well_request_type, target_purpose: nil, for_multiplexing: true, pooling_method: @pooling) @pe_request_type = - create :request_type, - asset_type: 'LibraryTube', - initial_state: 'pending', - name: 'PE sequencing', - order: 2, - key: 'pe_sequencing' + create( + :request_type, + asset_type: 'LibraryTube', + initial_state: 'pending', + name: 'PE sequencing', + order: 2, + key: 'pe_sequencing' + ) @mx_request_type_ids = [@mx_request_type.id, @pe_request_type.id] @ux_request_type_ids = [@ux_request_type.id, @pe_request_type.id] diff --git a/test/unit/fluidigm_plate_test.rb b/test/unit/fluidigm_plate_test.rb index a248ad5577..49be6195fa 100644 --- a/test/unit/fluidigm_plate_test.rb +++ b/test/unit/fluidigm_plate_test.rb @@ -7,7 +7,7 @@ class FluidigmPlateTest < ActiveSupport::TestCase setup do barcode = build(:plate_barcode) PlateBarcode.stubs(:create_barcode).returns(barcode) - @plate = create(:fluidigm_96_purpose).create!(barcode: barcode) + @plate = create(:fluidigm_96_purpose).create!(barcode:) end should 'have 96 wells' do @@ -28,7 +28,7 @@ class FluidigmPlateTest < ActiveSupport::TestCase setup do barcode = build(:plate_barcode) PlateBarcode.stubs(:create_barcode).returns(barcode) - @plate = create(:fluidigm_192_purpose).create!(barcode: barcode) + @plate = create(:fluidigm_192_purpose).create!(barcode:) end should 'have 192 wells' do diff --git a/test/unit/import_fluidigm_data_test.rb b/test/unit/import_fluidigm_data_test.rb index 52ba361280..b0aa88ffb2 100644 --- a/test/unit/import_fluidigm_data_test.rb +++ b/test/unit/import_fluidigm_data_test.rb @@ -29,41 +29,47 @@ def create_fluidigm_file end def create_stock_plate(barcode) - create :plate, - name: "Stock plate #{barcode}", - well_count: 1, - well_factory: :untagged_well, - purpose: PlatePurpose.stock_plate_purpose, - barcode: barcode + create( + :plate, + name: "Stock plate #{barcode}", + well_count: 1, + well_factory: :untagged_well, + purpose: PlatePurpose.stock_plate_purpose, + barcode: barcode + ) end def create_plate_with_fluidigm(_barcode, fluidigm_barcode, stock_plate) - fgp = create :fluidigm_96_purpose + fgp = create(:fluidigm_96_purpose) plate_target = - create :plate, - size: 96, - purpose: fgp, - well_count: 1, - well_factory: :empty_well, - fluidigm_barcode: fluidigm_barcode + create( + :plate, + size: 96, + purpose: fgp, + well_count: 1, + well_factory: :empty_well, + fluidigm_barcode: fluidigm_barcode + ) well_target = plate_target.wells.first - create :final_cherrypick_for_fluidigm_request, - state: 'passed', - asset: stock_plate.wells.first, - target_asset: well_target, - request_metadata_attributes: { - target_purpose_id: fgp.id - }, - request_type: @fluidigm_request_type + create( + :final_cherrypick_for_fluidigm_request, + state: 'passed', + asset: stock_plate.wells.first, + target_asset: well_target, + request_metadata_attributes: { + target_purpose_id: fgp.id + }, + request_type: @fluidigm_request_type + ) plate_target end context 'With a fluidigm file' do setup do - @fluidigm_request_type = create :request_type, key: 'pick_to_fluidigm' + @fluidigm_request_type = create(:request_type, key: 'pick_to_fluidigm') @fluidigm_file = create_fluidigm_file @stock_plate = create_stock_plate('SQPD-8765432') @plate1 = create_plate_with_fluidigm('1234567', '1381832088', @stock_plate) diff --git a/test/unit/lab_interface/workflow_test.rb b/test/unit/lab_interface/workflow_test.rb index 2a29552977..641706a9eb 100644 --- a/test/unit/lab_interface/workflow_test.rb +++ b/test/unit/lab_interface/workflow_test.rb @@ -8,13 +8,13 @@ class WorkflowTest < ActiveSupport::TestCase should belong_to :pipeline setup do - pipeline = create :pipeline, name: 'Pipeline for WorkflowTest' + pipeline = create(:pipeline, name: 'Pipeline for WorkflowTest') @workflow = pipeline.workflow @workflow.update!(name: 'Workflow for WorkflowTest') - task = create :task, workflow: @workflow - create :descriptor, task: task, name: 'prop', value: 'something', key: 'something' - create :descriptor, task: task, name: 'prop_2', value: 'upstairs', key: 'upstairs' + task = create(:task, workflow: @workflow) + create(:descriptor, task: task, name: 'prop', value: 'something', key: 'something') + create(:descriptor, task: task, name: 'prop_2', value: 'upstairs', key: 'upstairs') end subject { @workflow } diff --git a/test/unit/lib_pool_norm_tube_generator_test.rb b/test/unit/lib_pool_norm_tube_generator_test.rb index 51ed05c490..f96db20da6 100644 --- a/test/unit/lib_pool_norm_tube_generator_test.rb +++ b/test/unit/lib_pool_norm_tube_generator_test.rb @@ -15,7 +15,7 @@ def valid_plate def setup @user = create(:admin) @study = create(:study) - create :between_tubes_transfer_template # Needed by LibPoolNormTubeGenerator.new + create(:between_tubes_transfer_template) # Needed by LibPoolNormTubeGenerator.new end def mock_transfer(generator) diff --git a/test/unit/library_tube_test.rb b/test/unit/library_tube_test.rb index 2753551959..9bff6287e3 100644 --- a/test/unit/library_tube_test.rb +++ b/test/unit/library_tube_test.rb @@ -4,12 +4,12 @@ class LibraryTubeTest < ActiveSupport::TestCase context 'A Library tube' do - setup { @library_tube = create :library_tube } + setup { @library_tube = create(:library_tube) } context '#has_stock_asset?' do setup do - @library_tube_with_stock_tube = create :library_tube - @stock_library_tube = create :stock_library_tube + @library_tube_with_stock_tube = create(:library_tube) + @stock_library_tube = create(:stock_library_tube) @stock_library_tube.children << @library_tube_with_stock_tube end diff --git a/test/unit/messaging/messenger_creator_test.rb b/test/unit/messaging/messenger_creator_test.rb index 99beccbbb2..5a6fa8dad9 100644 --- a/test/unit/messaging/messenger_creator_test.rb +++ b/test/unit/messaging/messenger_creator_test.rb @@ -5,13 +5,13 @@ class MessengerCreatorTest < ActiveSupport::TestCase context '#messenger_creator' do setup do - @purpose = FactoryBot.build :plate_purpose - @plate = FactoryBot.build :plate, plate_purpose: @purpose + @purpose = FactoryBot.build(:plate_purpose) + @plate = FactoryBot.build(:plate, plate_purpose: @purpose) end context 'with SelfFinder' do setup do - @messenger_creator = FactoryBot.build :messenger_creator, purpose: @purpose + @messenger_creator = FactoryBot.build(:messenger_creator, purpose: @purpose) @start_count = Messenger.count end @@ -33,7 +33,7 @@ class MessengerCreatorTest < ActiveSupport::TestCase context 'with WellFinder' do setup do @messenger_creator = - build :messenger_creator, purpose: @purpose, target_finder_class: 'WellFinder', root: 'well' + build(:messenger_creator, purpose: @purpose, target_finder_class: 'WellFinder', root: 'well') @start_count = Messenger.count @plate.save 3.times { @plate.wells << build(:well) } diff --git a/test/unit/multiplexed_library_tube_test.rb b/test/unit/multiplexed_library_tube_test.rb index f1f55ac50a..4eb8b702a9 100644 --- a/test/unit/multiplexed_library_tube_test.rb +++ b/test/unit/multiplexed_library_tube_test.rb @@ -4,11 +4,11 @@ class MultiplexedLibraryTubeTest < ActiveSupport::TestCase context 'A multiplexed Library tube' do - setup { @multiplexed_library_tube = create :multiplexed_library_tube } + setup { @multiplexed_library_tube = create(:multiplexed_library_tube) } context '#has_stock_asset?' do setup do - @multiplexed_library_tube_with_stock_tube = create :multiplexed_library_tube - @stock_multiplexed_library_tube = create :stock_multiplexed_library_tube + @multiplexed_library_tube_with_stock_tube = create(:multiplexed_library_tube) + @stock_multiplexed_library_tube = create(:stock_multiplexed_library_tube) @stock_multiplexed_library_tube.children << @multiplexed_library_tube_with_stock_tube end diff --git a/test/unit/parsers/quant_parser_test.rb b/test/unit/parsers/quant_parser_test.rb index bb45d82fa4..8463c16acf 100644 --- a/test/unit/parsers/quant_parser_test.rb +++ b/test/unit/parsers/quant_parser_test.rb @@ -28,7 +28,7 @@ def read_file(filename) context 'processing the file' do setup do @parser = Parsers.parser_for(@filename, nil, @content) - @plate = create :plate, well_count: 18 + @plate = create(:plate, well_count: 18) @default_conc = @plate.wells.first.get_concentration @plate.update_qc_values_with_parser(@parser) @wells = @plate.reload.wells.index_by(&:map_description) @@ -56,8 +56,8 @@ def read_file(filename) @filename = Rails.root.join('test/data/complete_quant_test.csv').to_s @content = read_file @filename @parser = Parsers.parser_for(@filename, nil, @content) - @plate = create :working_dilution_plate, well_count: 18, plate_metadata_attributes: { dilution_factor: 10 } - @parent = create :plate, well_count: 18 + @plate = create(:working_dilution_plate, well_count: 18, plate_metadata_attributes: { dilution_factor: 10 }) + @parent = create(:plate, well_count: 18) @plate.parents << @parent @default_conc = @plate.wells.reload.first.get_concentration @plate.update_qc_values_with_parser(@parser) @@ -106,7 +106,7 @@ def read_file(filename) context 'processing the file' do setup do @parser = Parsers.parser_for(@filename, nil, @content) - @plate = create :plate, well_count: 18 + @plate = create(:plate, well_count: 18) @default_conc = @plate.wells.first.get_concentration @plate.update_qc_values_with_parser(@parser) @wells = @plate.wells.reload.index_by(&:map_description) diff --git a/test/unit/pipeline_test.rb b/test/unit/pipeline_test.rb index 08e69eb38e..77d0e573e0 100644 --- a/test/unit/pipeline_test.rb +++ b/test/unit/pipeline_test.rb @@ -14,10 +14,10 @@ class PipelineTest < ActiveSupport::TestCase context 'sequencing_pipeline#read length consistency among batch requests' do setup do - @sample = create :sample + @sample = create(:sample) - @request_type = create :request_type, name: 'sequencing', target_asset_type: nil - @pipeline = create :sequencing_pipeline, name: 'sequencing pipeline', request_types: [@request_type] + @request_type = create(:request_type, name: 'sequencing', target_asset_type: nil) + @pipeline = create(:sequencing_pipeline, name: 'sequencing pipeline', request_types: [@request_type]) @request1 = create( :sequencing_request, @@ -36,7 +36,7 @@ class PipelineTest < ActiveSupport::TestCase end should 'return true if not any request was selected' do - @batch = create :batch + @batch = create(:batch) assert @pipeline.is_read_length_consistent_for_batch?(@batch) end @@ -59,7 +59,7 @@ class PipelineTest < ActiveSupport::TestCase end should 'check that other pipelines are not affected by different read_length attributes' do - @pipeline2 = create :pipeline, name: 'other pipeline', request_types: [@request_type] + @pipeline2 = create(:pipeline, name: 'other pipeline', request_types: [@request_type]) @request1 = create( :sequencing_request, @@ -85,10 +85,10 @@ class PipelineTest < ActiveSupport::TestCase context 'sequencing_pipeline#requested_flowcell_type consistency among batch requests' do setup do - @sample = create :sample + @sample = create(:sample) - @request_type = create :request_type, name: 'sequencing', target_asset_type: nil - @pipeline = create :sequencing_pipeline, name: 'sequencing pipeline', request_types: [@request_type] + @request_type = create(:request_type, name: 'sequencing', target_asset_type: nil) + @pipeline = create(:sequencing_pipeline, name: 'sequencing pipeline', request_types: [@request_type]) @request1 = create( :sequencing_request, @@ -107,7 +107,7 @@ class PipelineTest < ActiveSupport::TestCase end should 'return true if no request was selected' do - @batch = create :batch + @batch = create(:batch) assert @pipeline.is_flowcell_type_consistent_for_batch?(@batch) end @@ -124,7 +124,7 @@ class PipelineTest < ActiveSupport::TestCase end should 'check that other pipelines are not affected by different requested_flowcell_type attributes' do - @pipeline2 = create :pipeline, name: 'other pipeline', request_types: [@request_type] + @pipeline2 = create(:pipeline, name: 'other pipeline', request_types: [@request_type]) @request1 = create( :sequencing_request, diff --git a/test/unit/plate_creator_test.rb b/test/unit/plate_creator_test.rb index 9e77d7f439..f3554593be 100644 --- a/test/unit/plate_creator_test.rb +++ b/test/unit/plate_creator_test.rb @@ -6,15 +6,15 @@ class CreatorTest < ActiveSupport::TestCase attr_reader :creator, :barcode_printer def setup - @creator_purpose = create :plate_purpose - @creator = create :plate_creator, plate_purposes: [@creator_purpose] - @barcode_printer = create :barcode_printer + @creator_purpose = create(:plate_purpose) + @creator = create(:plate_creator, plate_purposes: [@creator_purpose]) + @barcode_printer = create(:barcode_printer) end test 'should send request to print labels' do PlateBarcode.stubs(:create_barcode).returns(build(:plate_barcode)) - scanned_user = create :user + scanned_user = create(:user) create_asset_group = 'No' RestClient.expects(:post) @@ -41,8 +41,8 @@ def setup LabelPrinter::PrintJob.any_instance.stubs(:execute).returns(true) - parent = create :plate_with_untagged_wells - user = create :user + parent = create(:plate_with_untagged_wells) + user = create(:user) plate_count = Plate.count create_asset_group = 'No' diff --git a/test/unit/plate_owner_test.rb b/test/unit/plate_owner_test.rb index 3d6d1c79f0..5f1339dccd 100644 --- a/test/unit/plate_owner_test.rb +++ b/test/unit/plate_owner_test.rb @@ -17,8 +17,8 @@ class OwnerTest < ActionController::TestCase @barcode_printer.stubs(:each).returns(@barcode_printer) @barcode_printer.stubs(:blank?).returns(true) - @user = create :user - @parent_plate = create :plate + @user = create(:user) + @parent_plate = create(:plate) @pc_event = PlateCreation.create(user: @user, parent: @parent_plate, child_purpose: create(:plate_purpose)) @child_plate = @pc_event.child @@ -30,7 +30,7 @@ class OwnerTest < ActionController::TestCase end should 'be updated when stuff happens' do - @user2 = create :user + @user2 = create(:user) @tf_event = Transfer::BetweenPlates.create!( source: @parent_plate, diff --git a/test/unit/plate_template_test.rb b/test/unit/plate_template_test.rb index 1655aaee86..d341a1ba9a 100644 --- a/test/unit/plate_template_test.rb +++ b/test/unit/plate_template_test.rb @@ -6,7 +6,7 @@ class PlateTemplateTest < ActiveSupport::TestCase context 'A plate template' do context 'with no empty wells' do setup do - @template = create :plate_template + @template = create(:plate_template) @old_wells = Well.count @old_asset_link = AssetLink.count @template.update_params!(name: 'a', value: '2', wells: {}) @@ -19,7 +19,7 @@ class PlateTemplateTest < ActiveSupport::TestCase context 'with 1 empty well' do setup do - @template = create :plate_template + @template = create(:plate_template) @old_wells = Well.count @template.update_params!(name: 'a', value: '2', wells: { 'A1' => '123' }) end @@ -30,7 +30,7 @@ class PlateTemplateTest < ActiveSupport::TestCase context 'with 2 empty wells' do setup do - @template = create :plate_template + @template = create(:plate_template) @old_wells = Well.count @old_asset_link = AssetLink.count @template.update_params!(name: 'a', value: '2', wells: { 'A1' => '123', 'B3' => '345' }) diff --git a/test/unit/plate_test.rb b/test/unit/plate_test.rb index 8e0124e709..0f41e4fa5f 100644 --- a/test/unit/plate_test.rb +++ b/test/unit/plate_test.rb @@ -5,7 +5,7 @@ class PlateTest < ActiveSupport::TestCase def create_plate_with_fluidigm(plate_barcode, fluidigm_barcode) - purpose = create :plate_purpose + purpose = create(:plate_purpose) purpose.create!( :do_not_create_wells, name: "Cherrypicked #{plate_barcode}", @@ -44,8 +44,8 @@ def create_plate_with_fluidigm(plate_barcode, fluidigm_barcode) context '#iteration' do setup do - @parent = create :plate, created_at: 6.hours.ago - tested_purpose = create :plate_purpose + @parent = create(:plate, created_at: 6.hours.ago) + tested_purpose = create(:plate_purpose) @parent.children << @child_a = create(:plate, plate_purpose: tested_purpose, created_at: 5.hours.ago) @parent.children << @child_b = create(:plate, plate_purpose: tested_purpose, created_at: 4.hours.ago) @child_b.children << @dummy = create(:plate, plate_purpose: tested_purpose, created_at: 3.hours.ago) @@ -63,9 +63,9 @@ def create_plate_with_fluidigm(plate_barcode, fluidigm_barcode) context '#plate_ids_from_requests' do setup do - @plate1 = create :plate, :with_wells, well_count: 1 + @plate1 = create(:plate, :with_wells, well_count: 1) @well1 = @plate1.wells.first - @request1 = create :well_request, asset: @well1 + @request1 = create(:well_request, asset: @well1) end context 'with 1 request' do @@ -80,7 +80,7 @@ def create_plate_with_fluidigm(plate_barcode, fluidigm_barcode) setup do @well2 = Well.new @plate1.wells << @well2 - @request2 = create :well_request, asset: @well2 + @request2 = create(:well_request, asset: @well2) end context 'with a valid well assets' do should 'return a single plate ID' do @@ -93,12 +93,12 @@ def create_plate_with_fluidigm(plate_barcode, fluidigm_barcode) context 'with multiple requests on different plates' do setup do @well2 = Well.new - @plate2 = create :plate, :with_wells, well_count: 1 + @plate2 = create(:plate, :with_wells, well_count: 1) @well2 = @plate2.wells.first - @request2 = create :well_request, asset: @well2 + @request2 = create(:well_request, asset: @well2) @well3 = Well.new @plate1.wells << @well3 - @request3 = create :well_request, asset: @well3 + @request3 = create(:well_request, asset: @well3) end context 'with a valid well assets' do should 'return 2 plate IDs' do @@ -113,10 +113,10 @@ def create_plate_with_fluidigm(plate_barcode, fluidigm_barcode) context 'Plate priority' do setup do - @plate = create :transfer_plate + @plate = create(:transfer_plate) user = create(:user) @plate.wells.each_with_index do |well, index| - create :request, asset: well, submission: Submission.create!(priority: index + 1, user: user) + create(:request, asset: well, submission: Submission.create!(priority: index + 1, user: user)) end end @@ -161,7 +161,7 @@ def create_plate_with_fluidigm(plate_barcode, fluidigm_barcode) context 'with existing well data' do setup do - @plate = create :plate_with_empty_wells, well_count: 3 + @plate = create(:plate_with_empty_wells, well_count: 3) @plate.wells.first.set_concentration('12') @plate.wells.first.set_molarity('34') @plate.update_qc_values_with_parser(MockParser.new) @@ -203,13 +203,13 @@ def create_plate_with_fluidigm(plate_barcode, fluidigm_barcode) context '::with_descendants_owned_by' do setup do - @user = create :user - @source_plate = create :source_plate - @child_plate = create :child_plate, parent: @source_plate + @user = create(:user) + @source_plate = create(:source_plate) + @child_plate = create(:child_plate, parent: @source_plate) end should 'find source plates with owners' do - create :plate_owner, user: @user, plate: @child_plate + create(:plate_owner, user: @user, plate: @child_plate) assert_includes Plate.with_descendants_owned_by(@user), @source_plate end diff --git a/test/unit/product_catalogue/library_driven_test.rb b/test/unit/product_catalogue/library_driven_test.rb index 3e41985130..a9fd6d6d9a 100644 --- a/test/unit/product_catalogue/library_driven_test.rb +++ b/test/unit/product_catalogue/library_driven_test.rb @@ -6,21 +6,23 @@ class LibraryDrivenTest < ActiveSupport::TestCase context 'When using a ProductCatalogue that is library driven' do setup do def link_product_with_pc(product, product_catalogue, library_type_name) - FactoryBot.create :product_product_catalogue, - product: product, - product_catalogue: product_catalogue, - selection_criterion: library_type_name + FactoryBot.create( + :product_product_catalogue, + product: product, + product_catalogue: product_catalogue, + selection_criterion: library_type_name + ) end # We'll create a product catalogue that will contain [@product, @product2, @product3] - @product = FactoryBot.create :product - @product2 = FactoryBot.create :product - @product3 = FactoryBot.create :product + @product = FactoryBot.create(:product) + @product2 = FactoryBot.create(:product) + @product3 = FactoryBot.create(:product) - @library_type = FactoryBot.create :library_type, name: 'LibraryType 1' - @library_type2 = FactoryBot.create :library_type, name: 'LibraryType 2' + @library_type = FactoryBot.create(:library_type, name: 'LibraryType 1') + @library_type2 = FactoryBot.create(:library_type, name: 'LibraryType 2') - @product_catalogue = FactoryBot.create :library_driven_product_catalogue + @product_catalogue = FactoryBot.create(:library_driven_product_catalogue) # The selection criterion is the library type name link_product_with_pc(@product, @product_catalogue, @library_type.name) @@ -32,23 +34,27 @@ def link_product_with_pc(product, product_catalogue, library_type_name) context 'with no library or incorrect type' do setup do @submission_template = - FactoryBot.create :submission_template, - name: 'ST 1', - product_catalogue: @product_catalogue, - submission_parameters: { - request_type_ids_list: [], - request_options: { - library_type: 'Another library' - } - } + FactoryBot.create( + :submission_template, + name: 'ST 1', + product_catalogue: @product_catalogue, + submission_parameters: { + request_type_ids_list: [], + request_options: { + library_type: 'Another library' + } + } + ) @submission_template2 = - FactoryBot.create :submission_template, - name: 'ST 2', - product_catalogue: @product_catalogue, - submission_parameters: { - request_type_ids_list: [] - } + FactoryBot.create( + :submission_template, + name: 'ST 2', + product_catalogue: @product_catalogue, + submission_parameters: { + request_type_ids_list: [] + } + ) end should 'not select any product (return nil)' do order = @submission_template.new_order @@ -70,26 +76,30 @@ def link_product_with_pc(product, product_catalogue, library_type_name) context 'with a library type selected' do setup do @submission_template = - FactoryBot.create :submission_template, - name: 'ST 1', - product_catalogue: @product_catalogue, - submission_parameters: { - request_type_ids_list: [], - request_options: { - library_type: @library_type.name - } - } + FactoryBot.create( + :submission_template, + name: 'ST 1', + product_catalogue: @product_catalogue, + submission_parameters: { + request_type_ids_list: [], + request_options: { + library_type: @library_type.name + } + } + ) @submission_template2 = - FactoryBot.create :submission_template, - name: 'ST 2', - product_catalogue: @product_catalogue, - submission_parameters: { - request_type_ids_list: [], - request_options: { - library_type: @library_type2.name - } - } + FactoryBot.create( + :submission_template, + name: 'ST 2', + product_catalogue: @product_catalogue, + submission_parameters: { + request_type_ids_list: [], + request_options: { + library_type: @library_type2.name + } + } + ) end should 'selects the right product for this submission using the library type' do @@ -104,12 +114,14 @@ def link_product_with_pc(product, product_catalogue, library_type_name) context 'without a library type selected' do setup do @submission_template3 = - FactoryBot.create :submission_template, - name: 'ST 3', - product_catalogue: @product_catalogue, - submission_parameters: { - request_type_ids_list: [] - } + FactoryBot.create( + :submission_template, + name: 'ST 3', + product_catalogue: @product_catalogue, + submission_parameters: { + request_type_ids_list: [] + } + ) end should 'select the first product of the default products' do @@ -120,15 +132,17 @@ def link_product_with_pc(product, product_catalogue, library_type_name) context 'with a library type unsupported by the product catalogue' do setup do @submission_template4 = - FactoryBot.create :submission_template, - name: 'ST 4', - product_catalogue: @product_catalogue, - submission_parameters: { - request_type_ids_list: [], - request_options: { - library_type: 'Standard' - } - } + FactoryBot.create( + :submission_template, + name: 'ST 4', + product_catalogue: @product_catalogue, + submission_parameters: { + request_type_ids_list: [], + request_options: { + library_type: 'Standard' + } + } + ) end should 'select the first product of the default products' do order = @submission_template4.new_order @@ -137,20 +151,22 @@ def link_product_with_pc(product, product_catalogue, library_type_name) end context 'with a library type that matches more than one product' do setup do - @product4 = FactoryBot.create :product + @product4 = FactoryBot.create(:product) link_product_with_pc(@product4, @product_catalogue, @library_type.name) @submission_template5 = - FactoryBot.create :submission_template, - name: 'ST 5', - product_catalogue: @product_catalogue, - submission_parameters: { - request_type_ids_list: [], - request_options: { - library_type: @library_type.name - } - } + FactoryBot.create( + :submission_template, + name: 'ST 5', + product_catalogue: @product_catalogue, + submission_parameters: { + request_type_ids_list: [], + request_options: { + library_type: @library_type.name + } + } + ) end should 'select the first product of the default products' do order = @submission_template5.new_order diff --git a/test/unit/product_catalogue_test.rb b/test/unit/product_catalogue_test.rb index abb7a78427..96de57b9a4 100644 --- a/test/unit/product_catalogue_test.rb +++ b/test/unit/product_catalogue_test.rb @@ -9,8 +9,8 @@ class ProductCatalogueTest < ActiveSupport::TestCase context 'with single product behaviour' do setup do - @catalogue = create :single_product_catalogue - @product = create :product + @catalogue = create(:single_product_catalogue) + @product = create(:product) @catalogue.products << @product end @@ -24,14 +24,14 @@ class ProductCatalogueTest < ActiveSupport::TestCase context 'with invalid behaviour' do should 'reject non-existant behaviours' do assert_raise(ActiveRecord::RecordInvalid) do - create :product_catalogue, selection_behaviour: 'InvalidSelectionBehaviour' + create(:product_catalogue, selection_behaviour: 'InvalidSelectionBehaviour') end end end context 'with global constants for behaviour' do should 'reject behaviours' do - assert_raise(ActiveRecord::RecordInvalid) { create :product_catalogue, selection_behaviour: 'File' } + assert_raise(ActiveRecord::RecordInvalid) { create(:product_catalogue, selection_behaviour: 'File') } end end end @@ -40,7 +40,7 @@ class ProductCatalogueTest < ActiveSupport::TestCase setup do @catalogue_count = ProductCatalogue.count - @existing_product = create :product, name: 'pre_existing' + @existing_product = create(:product, name: 'pre_existing') @product_count = Product.count @product_product_catalogue_count = ProductProductCatalogue.count diff --git a/test/unit/product_criteria/advanced_test.rb b/test/unit/product_criteria/advanced_test.rb index a339714010..266392d2a6 100644 --- a/test/unit/product_criteria/advanced_test.rb +++ b/test/unit/product_criteria/advanced_test.rb @@ -28,10 +28,10 @@ class ProductCriteriaAdvancedTest < ActiveSupport::TestCase context 'with a list of target wells' do setup do @well_attribute = - create :well_attribute, concentration: 800, current_volume: 100, gel_pass: 'OKAY', gender_markers: %w[M M U] - @well = create :well, well_attribute: @well_attribute + create(:well_attribute, concentration: 800, current_volume: 100, gel_pass: 'OKAY', gender_markers: %w[M M U]) + @well = create(:well, well_attribute: @well_attribute) - @target_wells = create_list :well, 7 + @target_wells = create_list(:well, 7) @target_wells[4].well_attribute.update(concentration: 30, updated_at: 1.hour.from_now) @criteria = ProductCriteria::Advanced.new(@params, @well, @target_wells) end @@ -50,8 +50,8 @@ class ProductCriteriaAdvancedTest < ActiveSupport::TestCase context 'with a good well' do setup do - @well_attribute = create :well_attribute, concentration: 800, measured_volume: 200 - @well = create :well, well_attribute: @well_attribute + @well_attribute = create(:well_attribute, concentration: 800, measured_volume: 200) + @well = create(:well, well_attribute: @well_attribute) @criteria = ProductCriteria::Advanced.new(@params, @well) end @@ -63,8 +63,8 @@ class ProductCriteriaAdvancedTest < ActiveSupport::TestCase context 'with a bad well' do setup do - @well_attribute = create :well_attribute, concentration: 200, measured_volume: 50 - @well = create :well, well_attribute: @well_attribute + @well_attribute = create(:well_attribute, concentration: 200, measured_volume: 50) + @well = create(:well, well_attribute: @well_attribute) @criteria = ProductCriteria::Advanced.new(@params, @well) end @@ -76,8 +76,8 @@ class ProductCriteriaAdvancedTest < ActiveSupport::TestCase context 'with a very bad well' do setup do - @well_attribute = create :well_attribute, concentration: 1, measured_volume: 30_000 - @well = create :well, well_attribute: @well_attribute + @well_attribute = create(:well_attribute, concentration: 1, measured_volume: 30_000) + @well = create(:well, well_attribute: @well_attribute) @criteria = ProductCriteria::Advanced.new(@params, @well) end diff --git a/test/unit/product_criteria/basic_test.rb b/test/unit/product_criteria/basic_test.rb index 37777794af..001babfb3e 100644 --- a/test/unit/product_criteria/basic_test.rb +++ b/test/unit/product_criteria/basic_test.rb @@ -28,9 +28,9 @@ class ProductCriteriaBasicTest < ActiveSupport::TestCase context 'with a bad well' do setup do @well_attribute = - create :well_attribute, concentration: 1, current_volume: 30_000, gel_pass: 'OKAY', gender_markers: %w[M M U] - @well = create :well, well_attribute: @well_attribute - @sample = create :sample, sample_metadata_attributes: { gender: 'female' } + create(:well_attribute, concentration: 1, current_volume: 30_000, gel_pass: 'OKAY', gender_markers: %w[M M U]) + @well = create(:well, well_attribute: @well_attribute) + @sample = create(:sample, sample_metadata_attributes: { gender: 'female' }) @well.samples << @sample @criteria = ProductCriteria::Basic.new(@params, @well) end @@ -56,9 +56,9 @@ class ProductCriteriaBasicTest < ActiveSupport::TestCase context 'with a good well' do setup do @well_attribute = - create :well_attribute, concentration: 800, current_volume: 100, gel_pass: 'OKAY', gender_markers: %w[M M U] - @well = create :well, well_attribute: @well_attribute - @sample = create :sample, sample_metadata_attributes: { gender: 'male' } + create(:well_attribute, concentration: 800, current_volume: 100, gel_pass: 'OKAY', gender_markers: %w[M M U]) + @well = create(:well, well_attribute: @well_attribute) + @sample = create(:sample, sample_metadata_attributes: { gender: 'male' }) @well.samples << @sample @criteria = ProductCriteria::Basic.new(@params, @well) end diff --git a/test/unit/product_criteria_test.rb b/test/unit/product_criteria_test.rb index df89eac787..11d77e69ec 100644 --- a/test/unit/product_criteria_test.rb +++ b/test/unit/product_criteria_test.rb @@ -10,24 +10,24 @@ class ProductCriteriaTest < ActiveSupport::TestCase should validate_presence_of :behaviour setup do - @product_a = create :product + @product_a = create(:product) @criteria_a = - create :product_criteria, product: @product_a, configuration: { total_micrograms: { greater_than: 50 } } + create(:product_criteria, product: @product_a, configuration: { total_micrograms: { greater_than: 50 } }) end should 'only allow one active criteria per product per stage' do - assert_raise(ActiveRecord::RecordInvalid) { create :product_criteria, product: @product_a } + assert_raise(ActiveRecord::RecordInvalid) { create(:product_criteria, product: @product_a) } end should 'allow multiple active criteria with different stages' do - @criteria_b = create :product_criteria, product: @product_a, stage: 'another_stage' + @criteria_b = create(:product_criteria, product: @product_a, stage: 'another_stage') assert @criteria_b.valid? end should 'allow products with the same name if one is deprecated' do @criteria_a.deprecated_at = Time.zone.now @criteria_a.save - @criteria_2 = create :product_criteria, product: @product_a + @criteria_2 = create(:product_criteria, product: @product_a) assert @criteria_2.valid? end @@ -35,7 +35,7 @@ class ProductCriteriaTest < ActiveSupport::TestCase assert_equal 1, @criteria_a.version @criteria_a.deprecated_at = Time.zone.now @criteria_a.save - @criteria_b = create :product_criteria, product: @product_a + @criteria_b = create(:product_criteria, product: @product_a) assert_equal 2, @criteria_b.version end @@ -63,8 +63,8 @@ class ProductCriteriaTest < ActiveSupport::TestCase end should 'validate wells with the provided criteria' do - well_attribute = create :well_attribute, concentration: 800, current_volume: 100 - well = create :well, well_attribute: well_attribute + well_attribute = create(:well_attribute, concentration: 800, current_volume: 100) + well = create(:well, well_attribute:) assesment = @criteria_a.assess(well) assert assesment.is_a?(ProductCriteria::Basic) assert assesment.passed? diff --git a/test/unit/product_test.rb b/test/unit/product_test.rb index 20b7804a02..cbcc66e0ef 100644 --- a/test/unit/product_test.rb +++ b/test/unit/product_test.rb @@ -11,18 +11,18 @@ class ProductTest < ActiveSupport::TestCase should validate_presence_of :name should 'only allow one active product with each name' do - @product_a = create :product - assert_raise(ActiveRecord::RecordInvalid) { @product_b = create :product, name: @product_a.name } + @product_a = create(:product) + assert_raise(ActiveRecord::RecordInvalid) { @product_b = create(:product, name: @product_a.name) } end should 'allow products with the same name if one is deprecated' do - @product_a = create :product, deprecated_at: Time.zone.now - @product_b = create :product, name: @product_a.name + @product_a = create(:product, deprecated_at: Time.zone.now) + @product_b = create(:product, name: @product_a.name) assert @product_b.valid? end should 'not be destroyable' do - @product_a = create :product + @product_a = create(:product) # ActiveRecord::RecordNotDestroyed is the Rails4 exception for this # Added here as Rails 2 is a bit useless with appropriate exceptions @@ -30,7 +30,7 @@ class ProductTest < ActiveSupport::TestCase end should 'be deprecatable' do - @product_a = create :product + @product_a = create(:product) @product_a.deprecate! assert @product_a.deprecated? assert @product_a.deprecated_at != nil @@ -39,8 +39,8 @@ class ProductTest < ActiveSupport::TestCase context 'Product' do setup do - @product_a = create :product, deprecated_at: Time.zone.now - @product_b = create :product + @product_a = create(:product, deprecated_at: Time.zone.now) + @product_b = create(:product) end context '::active' do diff --git a/test/unit/purpose_test.rb b/test/unit/purpose_test.rb index 7107b7dc65..8020415d11 100644 --- a/test/unit/purpose_test.rb +++ b/test/unit/purpose_test.rb @@ -4,6 +4,6 @@ class PurposeTest < ActiveSupport::TestCase context 'A purpose' do - setup { @purpose = create :purpose } + setup { @purpose = create(:purpose) } end end diff --git a/test/unit/qc_file_test.rb b/test/unit/qc_file_test.rb index 2bbbc077f7..dae247325f 100644 --- a/test/unit/qc_file_test.rb +++ b/test/unit/qc_file_test.rb @@ -6,7 +6,7 @@ class QcFileTest < ActiveSupport::TestCase context QcFile do context 'with an asset' do setup do - @plate = create :plate + @plate = create(:plate) @parser = Object.new Parsers.expects(:parser_for).returns(@parser) end diff --git a/test/unit/qc_metric_test.rb b/test/unit/qc_metric_test.rb index 3573fb0649..10eef529bf 100644 --- a/test/unit/qc_metric_test.rb +++ b/test/unit/qc_metric_test.rb @@ -27,7 +27,7 @@ class QcMetricTest < ActiveSupport::TestCase ['manually_passed', nil, false] ].each do |qc_state, proceed_state, poor_quality_proceed| should "return #{poor_quality_proceed} when the qc_state is #{qc_state} and proceed is #{proceed_state}" do - qc = create :qc_metric, qc_decision: qc_state, proceed: proceed_state + qc = create(:qc_metric, qc_decision: qc_state, proceed: proceed_state) assert_equal poor_quality_proceed, qc.poor_quality_proceed end end @@ -42,22 +42,22 @@ class QcMetricTest < ActiveSupport::TestCase ['unprocessable', false, true] ].each do |qc_state, proceedable, set_suboptimal| should "#{proceedable ? '' : 'not '}allow the proceed flag to be set to Y when #{qc_state}" do - qc = create :qc_metric, qc_decision: qc_state + qc = create(:qc_metric, qc_decision: qc_state) qc.human_proceed = 'Y' assert_equal proceedable, qc.proceed end should "allow the proceed flag to be set to N when #{qc_state}" do - qc = create :qc_metric, qc_decision: qc_state + qc = create(:qc_metric, qc_decision: qc_state) qc.human_proceed = 'N' assert_equal false, qc.proceed end should "#{set_suboptimal ? '' : 'not '}flag the aliquot as suboptimal when #{qc_state}" do - aliquot = create :aliquot - well = create :well + aliquot = create(:aliquot) + well = create(:well) well.aliquots << aliquot - create :qc_metric, qc_decision: qc_state, asset: well + create(:qc_metric, qc_decision: qc_state, asset: well) # The data NEEDS to be persisted, so we reload to check this is the case. aliquot.reload diff --git a/test/unit/qc_report_file_test.rb b/test/unit/qc_report_file_test.rb index e76e47bfd0..c8555d3362 100644 --- a/test/unit/qc_report_file_test.rb +++ b/test/unit/qc_report_file_test.rb @@ -62,20 +62,22 @@ class QcReport::FileTest < ActiveSupport::TestCase context 'given a file with a report' do setup do - @product = create :product, name: 'Demo Product' - @criteria = create :product_criteria, product: @product, version: 1 - @study = create :study, name: 'Example study' + @product = create(:product, name: 'Demo Product') + @criteria = create(:product_criteria, product: @product, version: 1) + @study = create(:study, name: 'Example study') Timecop.freeze(DateTime.parse('01/01/2015')) do @report = - create :qc_report, - study: @study, - exclude_existing: false, - product_criteria: @criteria, - state: 'awaiting_proceed' + create( + :qc_report, + study: @study, + exclude_existing: false, + product_criteria: @criteria, + state: 'awaiting_proceed' + ) end @asset_ids = [] 2.times do |i| - create :qc_metric, qc_report: @report, qc_decision: %w[passed failed][i], asset: create(:well, id: i + 1) + create(:qc_metric, qc_report: @report, qc_decision: %w[passed failed][i], asset: create(:well, id: i + 1)) end @file = fixture_file_upload("#{Rails.root}/test/data/qc_report.csv", 'text/csv') @@ -104,20 +106,22 @@ class QcReport::FileTest < ActiveSupport::TestCase context 'On overriding' do setup do - @product = FactoryBot.build :product, name: 'Demo Product' - @criteria = FactoryBot.build :product_criteria, product: @product, version: 1 - @study = FactoryBot.build :study, name: 'Example study' + @product = FactoryBot.build(:product, name: 'Demo Product') + @criteria = FactoryBot.build(:product_criteria, product: @product, version: 1) + @study = FactoryBot.build(:study, name: 'Example study') Timecop.freeze(DateTime.parse('01/01/2015')) do @report = - create :qc_report, - study: @study, - exclude_existing: false, - product_criteria: @criteria, - state: 'awaiting_proceed' + create( + :qc_report, + study: @study, + exclude_existing: false, + product_criteria: @criteria, + state: 'awaiting_proceed' + ) end @asset_ids = [] 2.times do |i| - m = create :qc_metric, qc_report: @report, qc_decision: %w[passed failed][i], asset: create(:well, id: i + 1) + m = create(:qc_metric, qc_report: @report, qc_decision: %w[passed failed][i], asset: create(:well, id: i + 1)) @asset_ids << m.asset_id end @file = fixture_file_upload("#{Rails.root}/test/data/qc_report.csv", 'text/csv') @@ -135,19 +139,21 @@ class QcReport::FileTest < ActiveSupport::TestCase context 'With missing assets' do setup do - @product = FactoryBot.build :product, name: 'Demo Product' - @criteria = FactoryBot.build :product_criteria, product: @product, version: 1 - @study = FactoryBot.build :study, name: 'Example study' + @product = FactoryBot.build(:product, name: 'Demo Product') + @criteria = FactoryBot.build(:product_criteria, product: @product, version: 1) + @study = FactoryBot.build(:study, name: 'Example study') Timecop.freeze(DateTime.parse('01/01/2015')) do @report = - create :qc_report, - study: @study, - exclude_existing: false, - product_criteria: @criteria, - state: 'awaiting_proceed' + create( + :qc_report, + study: @study, + exclude_existing: false, + product_criteria: @criteria, + state: 'awaiting_proceed' + ) end @asset_ids = [] - 2.times { |i| create :qc_metric, qc_report: @report, qc_decision: %w[passed failed][i] } + 2.times { |i| create(:qc_metric, qc_report: @report, qc_decision: %w[passed failed][i]) } @file = fixture_file_upload("#{Rails.root}/test/data/qc_report.csv", 'text/csv') @qcr_file = QcReport::File.new(@file, true, 'qc_report.csv', 'text/csv') diff --git a/test/unit/qc_report_presenter_test.rb b/test/unit/qc_report_presenter_test.rb index 1860405699..f9eb036a80 100644 --- a/test/unit/qc_report_presenter_test.rb +++ b/test/unit/qc_report_presenter_test.rb @@ -27,28 +27,32 @@ class QcReportPresenterTest < ActiveSupport::TestCase STATE_ARRAY = %w[passed failed].freeze setup do - @product = create :product, name: 'Demo Product' - @criteria = create :product_criteria, product: @product, version: 1 - @study = create :study, name: 'Example study' + @product = create(:product, name: 'Demo Product') + @criteria = create(:product_criteria, product: @product, version: 1) + @study = create(:study, name: 'Example study') Timecop.freeze(DateTime.parse('01/01/2015')) do @report = - create :qc_report, - study: @study, - exclude_existing: false, - created_at: DateTime.parse('01/01/2015 00:00:00'), - product_criteria: @criteria + create( + :qc_report, + study: @study, + exclude_existing: false, + created_at: DateTime.parse('01/01/2015 00:00:00'), + product_criteria: @criteria + ) end @asset_ids = [] 2.times do |i| m = - create :qc_metric, - qc_report: @report, - qc_decision: STATE_ARRAY[i], - metrics: { - total_micrograms: 10, - comment: 'X', - sanger_sample_id: 'EG' - } + create( + :qc_metric, + qc_report: @report, + qc_decision: STATE_ARRAY[i], + metrics: { + total_micrograms: 10, + comment: 'X', + sanger_sample_id: 'EG' + } + ) @asset_ids << m.asset_id end end diff --git a/test/unit/qc_report_test.rb b/test/unit/qc_report_test.rb index 86d5b392b0..ea75265275 100644 --- a/test/unit/qc_report_test.rb +++ b/test/unit/qc_report_test.rb @@ -15,26 +15,28 @@ class QcReportTest < ActiveSupport::TestCase context 'A QcReport' do context 'including existing' do setup do - @study = create :study - @other_study = create :study - @stock_plate = create :plate, purpose: PlatePurpose.find_or_create_by(name: 'Stock plate') + @study = create(:study) + @other_study = create(:study) + @stock_plate = create(:plate, purpose: PlatePurpose.find_or_create_by(name: 'Stock plate')) [@study, @other_study].each do |study| 2.times do |i| - attribute = create :well_attribute, current_volume: 500, concentration: 200 - sample = create(:study_sample, study: study).sample + attribute = create(:well_attribute, current_volume: 500, concentration: 200) + sample = create(:study_sample, study:).sample sample.update!(sanger_sample_id: 'TEST1') well = - create :well, - samples: [sample], - plate: @stock_plate, - map: create(:map, location_id: i), - well_attribute: attribute - well.aliquots.each { |a| a.update!(study: study) } + create( + :well, + samples: [sample], + plate: @stock_plate, + map: create(:map, location_id: i), + well_attribute: attribute + ) + well.aliquots.each { |a| a.update!(study:) } end end - @qc_report = create :qc_report, study: @study + @qc_report = create(:qc_report, study: @study) @qc_metric_count = QcMetric.count Delayed::Worker.new.work_off end @@ -65,65 +67,75 @@ class QcReportTest < ActiveSupport::TestCase context 'excluding existing' do # rubocop:todo Metrics/BlockLength setup do - @study = create :study - @stock_plate = create :plate, purpose: PlatePurpose.find_or_create_by(name: 'Stock plate') + @study = create(:study) + @stock_plate = create(:plate, purpose: PlatePurpose.find_or_create_by(name: 'Stock plate')) - @current_criteria = create :product_criteria - @other_criteria = create :product_criteria + @current_criteria = create(:product_criteria) + @other_criteria = create(:product_criteria) @matching_report = - create :qc_report, - study: @study, - exclude_existing: true, - product_criteria: @current_criteria, - report_identifier: 'Override' - @other_report = create :qc_report, study: @study, exclude_existing: true, product_criteria: @other_criteria + create( + :qc_report, + study: @study, + exclude_existing: true, + product_criteria: @current_criteria, + report_identifier: 'Override' + ) + @other_report = create(:qc_report, study: @study, exclude_existing: true, product_criteria: @other_criteria) - @attribute = create :well_attribute, current_volume: 500, concentration: 200 + @attribute = create(:well_attribute, current_volume: 500, concentration: 200) sample = create(:study_sample, study: @study).sample @unreported_sample = well = - create :well, - samples: [sample], - plate: @stock_plate, - map: create(:map, location_id: 1), - well_attribute: @attribute + create( + :well, + samples: [sample], + plate: @stock_plate, + map: create(:map, location_id: 1), + well_attribute: @attribute + ) well.aliquots.each { |a| a.update!(study: @study) } sample = create(:study_sample, study: @study).sample well = - create :well, - samples: [sample], - plate: @stock_plate, - map: create(:map, location_id: 2), - well_attribute: @attribute + create( + :well, + samples: [sample], + plate: @stock_plate, + map: create(:map, location_id: 2), + well_attribute: @attribute + ) well.aliquots.each { |a| a.update!(study: @study) } - create :qc_metric, asset: well, qc_report: @matching_report + create(:qc_metric, asset: well, qc_report: @matching_report) sample = create(:study_sample, study: @study).sample @other_reported_sample = well = - create :well, - samples: [sample], - plate: @stock_plate, - map: create(:map, location_id: 3), - well_attribute: @attribute + create( + :well, + samples: [sample], + plate: @stock_plate, + map: create(:map, location_id: 3), + well_attribute: @attribute + ) well.aliquots.each { |a| a.update!(study: @study) } - create :qc_metric, asset: well, qc_report: @other_report + create(:qc_metric, asset: well, qc_report: @other_report) sample = create(:study_sample, study: @study).sample well = - create :well, - samples: [sample], - plate: @stock_plate, - map: create(:map, location_id: 4), - well_attribute: @attribute + create( + :well, + samples: [sample], + plate: @stock_plate, + map: create(:map, location_id: 4), + well_attribute: @attribute + ) well.aliquots.each { |a| a.update!(study: @study) } - create :qc_metric, asset: well, qc_report: @matching_report - create :qc_metric, asset: well, qc_report: @other_report + create(:qc_metric, asset: well, qc_report: @matching_report) + create(:qc_metric, asset: well, qc_report: @other_report) - @qc_report = create :qc_report, study: @study, exclude_existing: true, product_criteria: @current_criteria + @qc_report = create(:qc_report, study: @study, exclude_existing: true, product_criteria: @current_criteria) @qc_metric_count = QcMetric.count @qc_report.generate! end @@ -141,7 +153,7 @@ class QcReportTest < ActiveSupport::TestCase context 'QcReport state machine' do setup do - @qc_report = create :qc_report + @qc_report = create(:qc_report) # Stub out report generation as it advances the state machine @qc_report.stubs(:generate_report) diff --git a/test/unit/sample_test.rb b/test/unit/sample_test.rb index 35c7fe7847..e12b0dcc3b 100644 --- a/test/unit/sample_test.rb +++ b/test/unit/sample_test.rb @@ -22,9 +22,9 @@ def assert_accession_service(type) context 'when used in older assets' do setup do - @sample = create :sample - @tube_a = create :empty_library_tube - @tube_b = create :empty_sample_tube + @sample = create(:sample) + @tube_a = create(:empty_library_tube) + @tube_b = create(:empty_sample_tube) create(:aliquot, sample: @sample, receptacle: @tube_b) create(:aliquot, sample: @sample, receptacle: @tube_a) @@ -36,7 +36,7 @@ def assert_accession_service(type) end context '#accession_number?' do - setup { @sample = create :sample } + setup { @sample = create(:sample) } context 'with nil accession number' do setup { @sample.sample_metadata.sample_ebi_accession_number = nil } should 'return false' do @@ -60,9 +60,9 @@ def assert_accession_service(type) context '#accession service' do context 'with one study' do setup do - @sample = create :sample - @study = create :open_study, accession_number: 'ENA123' - create :study_sample, study: @study, sample: @sample + @sample = create(:sample) + @study = create(:open_study, accession_number: 'ENA123') + create(:study_sample, study: @study, sample: @sample) end should 'delegate to the study' do assert_equal @study, @sample.primary_study @@ -71,9 +71,9 @@ def assert_accession_service(type) end context 'with one un-accessioned study' do setup do - @sample = create :sample - @study = create :open_study - create :study_sample, study: @study, sample: @sample + @sample = create(:sample) + @study = create(:open_study) + create(:study_sample, study: @study, sample: @sample) end should 'not delegate to the study' do assert_accession_service(:unsuitable) @@ -81,9 +81,9 @@ def assert_accession_service(type) end context 'with one un-accessioned, never study' do setup do - @sample = create :sample - @study = create :not_app_study - create :study_sample, study: @study, sample: @sample + @sample = create(:sample) + @study = create(:not_app_study) + create(:study_sample, study: @study, sample: @sample) end should 'not delegate to the study' do assert_accession_service(:none) @@ -94,11 +94,11 @@ def assert_accession_service(type) # and it reduces the risk of accidentally making human data public context 'with an ena and an ega study' do setup do - @sample = create :sample - @study = create :open_study, accession_number: 'ENA123' - @study_b = create :managed_study, accession_number: 'ENA123' - create :study_sample, study: @study, sample: @sample - create :study_sample, study: @study_b, sample: @sample + @sample = create(:sample) + @study = create(:open_study, accession_number: 'ENA123') + @study_b = create(:managed_study, accession_number: 'ENA123') + create(:study_sample, study: @study, sample: @sample) + create(:study_sample, study: @study_b, sample: @sample) end should 'delegate to the ega study' do assert_accession_service(:ega) @@ -107,11 +107,11 @@ def assert_accession_service(type) context 'with an ena and an ega study in the other order' do setup do - @sample = create :sample - @study = create :open_study, accession_number: 'ENA123' - @study_b = create :managed_study, accession_number: 'ENA123' - create :study_sample, study: @study_b, sample: @sample - create :study_sample, study: @study, sample: @sample + @sample = create(:sample) + @study = create(:open_study, accession_number: 'ENA123') + @study_b = create(:managed_study, accession_number: 'ENA123') + create(:study_sample, study: @study_b, sample: @sample) + create(:study_sample, study: @study, sample: @sample) end should 'still delegate to the ega study' do assert_accession_service(:ega) @@ -122,11 +122,11 @@ def assert_accession_service(type) # could be an issue. context 'with an accessioned ena but un-accessioned ena' do setup do - @sample = create :sample - @study = create :open_study, accession_number: 'ENA123' - @study_b = create :managed_study - create :study_sample, study: @study_b, sample: @sample - create :study_sample, study: @study, sample: @sample + @sample = create(:sample) + @study = create(:open_study, accession_number: 'ENA123') + @study_b = create(:managed_study) + create(:study_sample, study: @study_b, sample: @sample) + create(:study_sample, study: @study, sample: @sample) end should 'not delegate to either study' do assert_accession_service(:unsuitable) diff --git a/test/unit/sample_tube_test.rb b/test/unit/sample_tube_test.rb index 2e447c5c78..82d7830c9d 100644 --- a/test/unit/sample_tube_test.rb +++ b/test/unit/sample_tube_test.rb @@ -15,10 +15,10 @@ class SampleTubeTest < ActiveSupport::TestCase context 'can be rendered as a stock resource' do setup do Timecop.freeze(DateTime.parse('2012-03-11 10:22:42')) do - @sample_tube = create :empty_sample_tube, barcode: '12345' - @study = create :study - @sample = create :sample - @aliquot = create :aliquot, study: @study, sample: @sample, receptacle: @sample_tube + @sample_tube = create(:empty_sample_tube, barcode: '12345') + @study = create(:study) + @sample = create(:sample) + @aliquot = create(:aliquot, study: @study, sample: @sample, receptacle: @sample_tube) @messenger = @sample_tube.register_stock! end end diff --git a/test/unit/stock_library_tube_test.rb b/test/unit/stock_library_tube_test.rb index f5d9398859..c2fafd1393 100644 --- a/test/unit/stock_library_tube_test.rb +++ b/test/unit/stock_library_tube_test.rb @@ -4,7 +4,7 @@ class StockLibraryTubeTest < ActiveSupport::TestCase context 'A stock Library tube' do - setup { @stock_library = create :stock_library_tube } + setup { @stock_library = create(:stock_library_tube) } context '#has_stock_asset?' do should 'return false' do diff --git a/test/unit/stock_multiplexed_library_tube_test.rb b/test/unit/stock_multiplexed_library_tube_test.rb index fc1bf283db..cac41b8ad8 100644 --- a/test/unit/stock_multiplexed_library_tube_test.rb +++ b/test/unit/stock_multiplexed_library_tube_test.rb @@ -4,7 +4,7 @@ class StockMultiplexedLibraryTubeTest < ActiveSupport::TestCase context 'A stock multiplexed Library tube' do - setup { @stock_multiplexed_library = create :stock_multiplexed_library_tube } + setup { @stock_multiplexed_library = create(:stock_multiplexed_library_tube) } context '#has_stock_asset?' do should 'return false' do diff --git a/test/unit/submission_template_test.rb b/test/unit/submission_template_test.rb index 225e22ebaa..acc00995f8 100644 --- a/test/unit/submission_template_test.rb +++ b/test/unit/submission_template_test.rb @@ -7,7 +7,7 @@ class SubmissionTemplateTest < ActiveSupport::TestCase should validate_presence_of :product_catalogue setup do - @template = FactoryBot.build :submission_template + @template = FactoryBot.build(:submission_template) @product = create(:product) @template.product_catalogue.products << @product end @@ -31,9 +31,9 @@ class SubmissionTemplateTest < ActiveSupport::TestCase context 'without input_field_infos' do setup do - @library_type = create :library_type - @test_request_typ_b = create :library_creation_request_type, :with_library_types, library_type: @library_type - @test_request_type = create :sequencing_request_type + @library_type = create(:library_type) + @test_request_typ_b = create(:library_creation_request_type, :with_library_types, library_type: @library_type) + @test_request_type = create(:sequencing_request_type) @order.request_types = [@test_request_typ_b, @test_request_type] @order.request_type_ids_list = [[@test_request_typ_b.id], [@test_request_type.id]] end diff --git a/test/unit/tag_qc/lot_test.rb b/test/unit/tag_qc/lot_test.rb index 57a3a80124..3ef6b36eb8 100644 --- a/test/unit/tag_qc/lot_test.rb +++ b/test/unit/tag_qc/lot_test.rb @@ -14,7 +14,7 @@ class LotTest < ActiveSupport::TestCase should belong_to :template context 'when validating' do - setup { create :lot } + setup { create(:lot) } should validate_uniqueness_of(:lot_number).case_insensitive end @@ -22,14 +22,14 @@ class LotTest < ActiveSupport::TestCase context '#lot' do setup do PlateBarcode.stubs(:create_barcode).returns(build(:plate_barcode)) - @lot = create :lot + @lot = create(:lot) @mock_asset = Labware.new @mock_asset.stubs(:save!).returns(true) @mock_purpose = mock('Purpose') @mock_purpose.stubs('create!').returns(@mock_asset) @lot.stubs(:target_purpose).returns(@mock_purpose) - @user = create :user + @user = create(:user) end should 'validate the template type' do diff --git a/test/unit/tag_qc/plate_conversion_test.rb b/test/unit/tag_qc/plate_conversion_test.rb index 5724a37bcb..f83b53484c 100644 --- a/test/unit/tag_qc/plate_conversion_test.rb +++ b/test/unit/tag_qc/plate_conversion_test.rb @@ -10,8 +10,8 @@ class PlateConversionTest < ActiveSupport::TestCase context '#stamp' do should 'convert plates to a new purpose' do - @plate = create :plate - @user = create :user + @plate = create(:plate) + @user = create(:user) @purpose_b = PlatePurpose.new(name: 'test_purpose') PlateConversion.create!(target: @plate, user: @user, purpose: @purpose_b) @@ -20,9 +20,9 @@ class PlateConversionTest < ActiveSupport::TestCase end should 'set parents when supplied' do - @plate = create :plate - @parent = create :plate - @user = create :user + @plate = create(:plate) + @parent = create(:plate) + @user = create(:user) @purpose_b = PlatePurpose.new(name: 'test_purpose') PlateConversion.create!(target: @plate, user: @user, purpose: @purpose_b, parent: @parent) diff --git a/test/unit/tag_qc/qc_decision_test.rb b/test/unit/tag_qc/qc_decision_test.rb index 3d28c23dc9..10e3450280 100644 --- a/test/unit/tag_qc/qc_decision_test.rb +++ b/test/unit/tag_qc/qc_decision_test.rb @@ -13,12 +13,12 @@ class QcDecisionTest < ActiveSupport::TestCase context '#qc_decision' do setup do - @lot = create :lot - @user = create :user + @lot = create(:lot) + @user = create(:user) @user.roles.create!(name: 'qa_manager') - @user_b = create :user - @qcable_a = create :qcable, lot: @lot, state: 'pending' - @qcable_b = create :qcable, lot: @lot, state: 'pending' + @user_b = create(:user) + @qcable_a = create(:qcable, lot: @lot, state: 'pending') + @qcable_b = create(:qcable, lot: @lot, state: 'pending') end context 'with valid data' do diff --git a/test/unit/tag_qc/qcable_statemachine_checks.rb b/test/unit/tag_qc/qcable_statemachine_checks.rb index cf967ba00c..8d5e25b2bd 100644 --- a/test/unit/tag_qc/qcable_statemachine_checks.rb +++ b/test/unit/tag_qc/qcable_statemachine_checks.rb @@ -2,9 +2,9 @@ module QcableStatemachineChecks class StatemachineHelper - def initialize(owner, target, &block) + def initialize(owner, target, &) @owner, @target = owner, target - instance_eval(&block) + instance_eval(&) end # rubocop:todo Metrics/MethodLength @@ -46,7 +46,7 @@ def check_event(name, options) # rubocop:todo Metrics/AbcSize # rubocop:enable Metrics/MethodLength end - def state_machine(state_machined_class, &block) - StatemachineHelper.new(self, state_machined_class, &block) + def state_machine(state_machined_class, &) + StatemachineHelper.new(self, state_machined_class, &) end end diff --git a/test/unit/tag_qc/qcable_test.rb b/test/unit/tag_qc/qcable_test.rb index d105a27754..03c97f5b45 100644 --- a/test/unit/tag_qc/qcable_test.rb +++ b/test/unit/tag_qc/qcable_test.rb @@ -24,13 +24,13 @@ class QcableTest < ActiveSupport::TestCase context '#qcable' do setup do - @mock_purpose = build :tube_purpose, default_state: 'created' - @mock_lot = create :lot + @mock_purpose = build(:tube_purpose, default_state: 'created') + @mock_lot = create(:lot) @mock_lot.expects(:target_purpose).returns(@mock_purpose).twice end should 'create an asset of the given purpose' do - factory_attributes = attributes_for :qcable, lot: @mock_lot + factory_attributes = attributes_for(:qcable, lot: @mock_lot) @qcable = Qcable.create!(factory_attributes) assert_equal 'created', @qcable.state end @@ -38,16 +38,16 @@ class QcableTest < ActiveSupport::TestCase context '#qcable pre-pending' do setup do - @mock_purpose = build :tube_purpose, default_state: 'pending' + @mock_purpose = build(:tube_purpose, default_state: 'pending') @template = FactoryBot.build(:tag2_layout_template) - @lot_type = create :tag2_lot_type, target_purpose: @mock_purpose - @mock_lot = create :tag2_lot, lot_type: @lot_type + @lot_type = create(:tag2_lot_type, target_purpose: @mock_purpose) + @mock_lot = create(:tag2_lot, lot_type: @lot_type) end should 'create an asset of the given purpose' do # We can't use factory bot directly here, as it results in the initial state being # set BEFORE the lot is assigned. - factory_attributes = attributes_for :qcable, lot: @mock_lot + factory_attributes = attributes_for(:qcable, lot: @mock_lot) @qcable = Qcable.create!(factory_attributes) assert_equal @mock_purpose, @qcable.asset.purpose assert_equal 'pending', @qcable.state diff --git a/test/unit/tag_qc/stamp_test.rb b/test/unit/tag_qc/stamp_test.rb index 3074f432c5..abc75fdd21 100644 --- a/test/unit/tag_qc/stamp_test.rb +++ b/test/unit/tag_qc/stamp_test.rb @@ -18,29 +18,29 @@ class StampTest < ActiveSupport::TestCase context '#stamp' do should 'transition qcables to pending' do - @qcable = create :qcable_with_asset + @qcable = create(:qcable_with_asset) # Unfortunately we can't do this, as stamp looks for qcables directly. # @qcable.expects(:do_stamp!).returns(true) sqc = Stamp::StampQcable.new(bed: '1', order: 1, qcable: @qcable) - @stamp = create :stamp, stamp_qcables: [sqc] + @stamp = create(:stamp, stamp_qcables: [sqc]) assert_equal 'pending', @qcable.reload.state end should 'transfer samples' do - @qcable = create :qcable_with_asset + @qcable = create(:qcable_with_asset) # Unfortunately we can't do this, as stamp looks for qcables directly. # @qcable.expects(:do_stamp!).returns(true) sqc = Stamp::StampQcable.new(bed: '1', order: 1, qcable: @qcable) - @stamp = create :stamp, stamp_qcables: [sqc] + @stamp = create(:stamp, stamp_qcables: [sqc]) assert_equal 'pending', @qcable.reload.state assert_equal 1, @qcable.asset.wells.located_at('A2').first.aliquots.count end should 'clone the aliquots' do - @qcable = create :qcable_with_asset, state: 'created' + @qcable = create(:qcable_with_asset, state: 'created') @qcable_2 = @qcable.lot.qcables.create!( qcable_creator: @qcable.qcable_creator, @@ -50,7 +50,7 @@ class StampTest < ActiveSupport::TestCase sqc = Stamp::StampQcable.new(bed: '1', order: 1, qcable: @qcable) sqc_2 = Stamp::StampQcable.new(bed: '2', order: 2, qcable: @qcable_2) - @stamp = create :stamp, stamp_qcables: [sqc, sqc_2] + @stamp = create(:stamp, stamp_qcables: [sqc, sqc_2]) assert_equal 'pending', @qcable.reload.state assert_equal 1, @qcable.asset.wells.located_at('A2').first.aliquots.count assert_equal 'pending', @qcable_2.reload.state diff --git a/test/unit/task_test_base.rb b/test/unit/task_test_base.rb index f96455df58..1065b48701 100644 --- a/test/unit/task_test_base.rb +++ b/test/unit/task_test_base.rb @@ -11,10 +11,10 @@ def expected_partial(name) end end - def task_instance_for(task_module, &block) + def task_instance_for(task_module, &) object = Object.new object.class_eval { include task_module } - object.class_eval(&block) + object.class_eval(&) object end end diff --git a/test/unit/tasks/plate_transfer_task_test.rb b/test/unit/tasks/plate_transfer_task_test.rb index b9554e2080..e5e11d7a88 100644 --- a/test/unit/tasks/plate_transfer_task_test.rb +++ b/test/unit/tasks/plate_transfer_task_test.rb @@ -18,17 +18,17 @@ class PlateTransferTaskTest < ActiveSupport::TestCase context 'PlateTransferHandler' do setup do @workflows_controller = DummyWorkflowController.new - @task = create :plate_transfer_task + @task = create(:plate_transfer_task) @params = 'UNUSED_PARAMS' - @batch = create :batch + @batch = create(:batch) @workflows_controller.batch = @batch - @source_plate = create :plate - @user = build :user + @source_plate = create(:plate) + @user = build(:user) @source_plate.wells = %w[A1 B1 C1].map do |loc| create(:well_with_sample_and_without_plate).tap do |w| w.map = Map.find_by(description: loc, asset_size: 96) - request = create :pac_bio_sample_prep_request, asset: w + request = create(:pac_bio_sample_prep_request, asset: w) @batch.requests << request end end @@ -104,10 +104,10 @@ class PlateTransferTaskTest < ActiveSupport::TestCase context 'when spanning multiple plates' do setup do - plate_b = create :plate + plate_b = create(:plate) plate_b.wells << create(:well_with_sample_and_without_plate).tap do |w| w.map = Map.find_by(description: 'A1', asset_size: 96) - request = create :well_request, asset: w, target_asset: create(:pac_bio_library_tube) + request = create(:well_request, asset: w, target_asset: create(:pac_bio_library_tube)) w.requests << request @batch.requests << request end diff --git a/test/unit/transfer_templates/between_tubes_by_submission_test.rb b/test/unit/transfer_templates/between_tubes_by_submission_test.rb index 6f4ba2de12..10ff698f68 100644 --- a/test/unit/transfer_templates/between_tubes_by_submission_test.rb +++ b/test/unit/transfer_templates/between_tubes_by_submission_test.rb @@ -5,17 +5,17 @@ class TransferBetweenTubesBySubmissionTest < ActiveSupport::TestCase context 'A transfer between tubes by submission' do setup do - @user = create :user + @user = create(:user) - @tube_a = create :new_stock_multiplexed_library_tube - @plate_transfer_a = create :transfer_from_plate_to_tube_with_transfers, destination: @tube_a + @tube_a = create(:new_stock_multiplexed_library_tube) + @plate_transfer_a = create(:transfer_from_plate_to_tube_with_transfers, destination: @tube_a) @plate_a = @plate_transfer_a.source - @submission = create :submission_without_order + @submission = create(:submission_without_order) - @final_tube = create :multiplexed_library_tube + @final_tube = create(:multiplexed_library_tube) @plate_a.wells.each do |well| - create :library_completion, asset: well, target_asset: @final_tube, submission: @submission + create(:library_completion, asset: well, target_asset: @final_tube, submission: @submission) Well::Link.create(type: 'stock', source_well: well, target_well: well) well.transfer_requests_as_source.each do |request| request.submission = @submission @@ -36,12 +36,12 @@ class TransferBetweenTubesBySubmissionTest < ActiveSupport::TestCase # This gives us a little more versatility context 'in multiple rounds' do setup do - @tube_b = create :new_stock_multiplexed_library_tube - @plate_transfer_b = create :transfer_from_plate_to_tube_with_transfers, destination: @tube_b + @tube_b = create(:new_stock_multiplexed_library_tube) + @plate_transfer_b = create(:transfer_from_plate_to_tube_with_transfers, destination: @tube_b) @plate_b = @plate_transfer_b.source @plate_b.wells.each do |well| - create :library_completion, asset: well, target_asset: @final_tube, submission: @submission + create(:library_completion, asset: well, target_asset: @final_tube, submission: @submission) Well::Link.create(type: 'stock', source_well: well, target_well: well) well.transfer_requests_as_source.each do |request| request.submission = @submission diff --git a/test/unit/tube_test.rb b/test/unit/tube_test.rb index 966ef27e2f..7a4e8cc5e6 100644 --- a/test/unit/tube_test.rb +++ b/test/unit/tube_test.rb @@ -4,7 +4,7 @@ class TubeTest < ActiveSupport::TestCase test '#barcode! should add barcode to a tube' do - tube = create :unbarcoded_tube + tube = create(:unbarcoded_tube) assert_not tube.barcode_number tube.barcode! assert tube.barcode_number diff --git a/test/unit/user_test.rb b/test/unit/user_test.rb index 1328f2fc37..124727a364 100644 --- a/test/unit/user_test.rb +++ b/test/unit/user_test.rb @@ -6,7 +6,7 @@ class UserTest < ActiveSupport::TestCase context 'A User' do context 'authenticate' do setup do - @user = create :admin, login: 'xyz987', api_key: 'my_key', crypted_password: '1' + @user = create(:admin, login: 'xyz987', api_key: 'my_key', crypted_password: '1') @ldap = mock('LDAP') @ldap.stubs(:bind).returns(true) Net::LDAP.stubs(:new).returns(@ldap) @@ -22,7 +22,7 @@ class UserTest < ActiveSupport::TestCase end context 'is an administrator' do - setup { @user = create :admin } + setup { @user = create(:admin) } should 'be able to access admin functions' do assert @user.administrator? @@ -34,7 +34,7 @@ class UserTest < ActiveSupport::TestCase end context 'is a manager' do - setup { @user = create :manager } + setup { @user = create(:manager) } should 'not be able to access admin functions' do assert_not @user.administrator? @@ -50,7 +50,7 @@ class UserTest < ActiveSupport::TestCase end context 'is an owner' do - setup { @user = create :owner } + setup { @user = create(:owner) } should 'not be able to access admin functions' do assert_not @user.administrator? @@ -63,9 +63,9 @@ class UserTest < ActiveSupport::TestCase context 'admins and emails' do setup do - admin = create :role, name: 'administrator' - user1 = create :user, login: 'bla' - user2 = create :user, login: 'wow' + admin = create(:role, name: 'administrator') + user1 = create(:user, login: 'bla') + user2 = create(:user, login: 'wow') user2.roles << admin user1.roles << admin end @@ -81,7 +81,7 @@ class UserTest < ActiveSupport::TestCase context '#name' do context 'when profile is complete' do setup do - @user = create :user, first_name: 'Alan', last_name: 'Brown' + @user = create(:user, first_name: 'Alan', last_name: 'Brown') assert @user.valid? end should 'return full name' do @@ -90,7 +90,7 @@ class UserTest < ActiveSupport::TestCase end context 'when profile is incomplete' do setup do - @user = create :user, login: 'abc123', first_name: 'Alan', last_name: nil + @user = create(:user, login: 'abc123', first_name: 'Alan', last_name: nil) assert @user.valid? end should 'return login' do @@ -101,7 +101,7 @@ class UserTest < ActiveSupport::TestCase context '#new_api_key' do setup do - @user = create :user, first_name: 'Alan', last_name: 'Brown' + @user = create(:user, first_name: 'Alan', last_name: 'Brown') @old_api_key = @user.api_key @user.new_api_key @user.save @@ -113,7 +113,7 @@ class UserTest < ActiveSupport::TestCase end context 'without a swipecard_code' do - setup { @user = create :user } + setup { @user = create(:user) } should 'not have a swipecard code' do assert_equal false, @user.swipecard_code? @@ -126,7 +126,7 @@ class UserTest < ActiveSupport::TestCase end context 'is a data_access_coordinator' do - setup { @user = create :data_access_coordinator } + setup { @user = create(:data_access_coordinator) } should 'be able to access data_access_coordinator functions' do assert @user.data_access_coordinator? diff --git a/vite.config.ts b/vite.config.ts index 1abea1717d..d97d2c4b44 100644 --- a/vite.config.ts +++ b/vite.config.ts @@ -5,7 +5,10 @@ import { createVuePlugin } from "vite-plugin-vue2"; import legacy from "@vitejs/plugin-legacy"; export default defineConfig({ - build: { emptyOutDir: true }, + build: { + emptyOutDir: true, + target: ["chrome65", "es2019"], + }, plugins: [RubyPlugin(), createVuePlugin(), legacy({ targets: ["defaults"] })], resolve: { alias: { diff --git a/yarn.lock b/yarn.lock index 086c4d60ba..5f00b9aca4 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1934,6 +1934,11 @@ resolved "https://registry.yarnpkg.com/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.18.1.tgz#82ab3c575f4235fb647abea5e08eec6cf325964e" integrity sha512-F/tkdw0WSs4ojqz5Ovrw5r9odqzFjb5LIgHdHZG65dFI1lWTWRVy32KDJLKRISHgJvqUeUhdIvy43fX41znyDg== +"@rollup/rollup-darwin-arm64@*": + version "4.22.4" + resolved "https://registry.yarnpkg.com/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.22.4.tgz#6d241d099d1518ef0c2205d96b3fa52e0fe1954b" + integrity sha512-xMM9ORBqu81jyMKCDP+SZDhnX2QEVQzTcC6G18KlTQEzWK8r/oNZtKuZaCcHhnsa6fEeOBionoyl5JsAbE/36Q== + "@rollup/rollup-darwin-arm64@4.18.1": version "4.18.1" resolved "https://registry.yarnpkg.com/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.18.1.tgz#6a530452e68a9152809ce58de1f89597632a085b" @@ -1979,6 +1984,11 @@ resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.18.1.tgz#f1043d9f4026bf6995863cb3f8dd4732606e4baa" integrity sha512-qb1hMMT3Fr/Qz1OKovCuUM11MUNLUuHeBC2DPPAWUYYUAOFWaxInaTwTQmc7Fl5La7DShTEpmYwgdt2hG+4TEg== +"@rollup/rollup-linux-x64-gnu@*": + version "4.22.4" + resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.22.4.tgz#70116ae6c577fe367f58559e2cffb5641a1dd9d0" + integrity sha512-87v0ol2sH9GE3cLQLNEy0K/R0pz1nvg76o8M5nhMR0+Q+BBGLnb35P0fVz4CQxHYXaAOhE8HhlkaZfsdUOlHwg== + "@rollup/rollup-linux-x64-gnu@4.18.1": version "4.18.1" resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.18.1.tgz#1e781730be445119f06c9df5f185e193bc82c610" @@ -1999,6 +2009,11 @@ resolved "https://registry.yarnpkg.com/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.18.1.tgz#075b0713de627843a73b4cf0e087c56b53e9d780" integrity sha512-ELfEX1/+eGZYMaCIbK4jqLxO1gyTSOIlZr6pbC4SRYFaSIDVKOnZNMdoZ+ON0mrFDp4+H5MhwNC1H/AhE3zQLg== +"@rollup/rollup-win32-x64-msvc@*": + version "4.22.4" + resolved "https://registry.yarnpkg.com/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.22.4.tgz#3dd5d53e900df2a40841882c02e56f866c04d202" + integrity sha512-j8pPKp53/lq9lMXN57S8cFz0MynJk8OWNuUnXct/9KCpKU7DgU3bYMJhwWmcqC0UU29p8Lr0/7KEVcaM6bf47Q== + "@rollup/rollup-win32-x64-msvc@4.18.1": version "4.18.1" resolved "https://registry.yarnpkg.com/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.18.1.tgz#0cb240c147c0dfd0e3eaff4cc060a772d39e155c" @@ -7281,10 +7296,10 @@ vite-plugin-vue2@^1.9.3: source-map "^0.7.3" vue-template-es2015-compiler "^1.9.1" -vite@^5.3.2: - version "5.3.3" - resolved "https://registry.yarnpkg.com/vite/-/vite-5.3.3.tgz#5265b1f0a825b3b6564c2d07524777c83e3c04c2" - integrity sha512-NPQdeCU0Dv2z5fu+ULotpuq5yfCS1BzKUIPhNbP3YBfAMGJXbt2nS+sbTFu+qchaqWTD+H3JK++nRwr6XIcp6A== +vite@^5.3.6: + version "5.3.6" + resolved "https://registry.yarnpkg.com/vite/-/vite-5.3.6.tgz#e097c0a7b79adb2e60bec9ef7907354f09d027bd" + integrity sha512-es78AlrylO8mTVBygC0gTC0FENv0C6T496vvd33ydbjF/mIi9q3XQ9A3NWo5qLGFKywvz10J26813OkLvcQleA== dependencies: esbuild "^0.21.3" postcss "^8.4.39"