houston-core 0.5.0.beta1 → 0.5.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.codeclimate.yml +0 -2
- data/.gitignore +3 -0
- data/Gemfile +1 -0
- data/Gemfile.lock +63 -62
- data/README.md +13 -121
- data/app/adapters/houston/adapters/ci_server/errors.rb +4 -4
- data/app/adapters/houston/adapters/ci_server/jenkins_adapter/job.rb +50 -50
- data/app/adapters/houston/adapters/ci_server/jenkins_adapter.rb +4 -4
- data/app/adapters/houston/adapters/ci_server/none_adapter/job.rb +5 -5
- data/app/adapters/houston/adapters/ci_server/none_adapter.rb +4 -4
- data/app/adapters/houston/adapters/deployment/engineyard.rb +20 -20
- data/app/adapters/houston/adapters/error_tracker/errbit_adapter/app.rb +14 -14
- data/app/adapters/houston/adapters/error_tracker/errbit_adapter/connection.rb +41 -41
- data/app/adapters/houston/adapters/error_tracker/errbit_adapter/notice.rb +6 -6
- data/app/adapters/houston/adapters/error_tracker/errbit_adapter/problem.rb +25 -25
- data/app/adapters/houston/adapters/error_tracker/errbit_adapter.rb +20 -20
- data/app/adapters/houston/adapters/error_tracker/none_adapter.rb +8 -8
- data/app/adapters/houston/adapters/error_tracker/null_app.rb +13 -13
- data/app/adapters/houston/adapters/ticket_tracker/errors.rb +5 -5
- data/app/adapters/houston/adapters/ticket_tracker/github_adapter/connection.rb +41 -41
- data/app/adapters/houston/adapters/ticket_tracker/github_adapter/issue.rb +22 -22
- data/app/adapters/houston/adapters/ticket_tracker/github_adapter.rb +7 -7
- data/app/adapters/houston/adapters/ticket_tracker/houston_adapter/connection.rb +13 -13
- data/app/adapters/houston/adapters/ticket_tracker/houston_adapter/ticket.rb +15 -15
- data/app/adapters/houston/adapters/ticket_tracker/houston_adapter.rb +4 -4
- data/app/adapters/houston/adapters/ticket_tracker/none_adapter.rb +4 -4
- data/app/adapters/houston/adapters/ticket_tracker/null_connection.rb +13 -13
- data/app/adapters/houston/adapters/ticket_tracker/null_ticket.rb +19 -19
- data/app/adapters/houston/adapters/ticket_tracker/unfuddle_adapter/connection.rb +54 -54
- data/app/adapters/houston/adapters/ticket_tracker/unfuddle_adapter/milestone.rb +10 -10
- data/app/adapters/houston/adapters/ticket_tracker/unfuddle_adapter/ticket.rb +59 -59
- data/app/adapters/houston/adapters/ticket_tracker/unfuddle_adapter.rb +9 -9
- data/app/adapters/houston/adapters/version_control/commit.rb +4 -4
- data/app/adapters/houston/adapters/version_control/errors.rb +9 -9
- data/app/adapters/houston/adapters/version_control/git_adapter/github_repo.rb +15 -15
- data/app/adapters/houston/adapters/version_control/git_adapter/remote_repo.rb +53 -30
- data/app/adapters/houston/adapters/version_control/git_adapter/repo.rb +60 -55
- data/app/adapters/houston/adapters/version_control/git_adapter.rb +22 -22
- data/app/adapters/houston/adapters/version_control/none_adapter.rb +4 -4
- data/app/adapters/houston/adapters/version_control/null_commit.rb +4 -4
- data/app/adapters/houston/adapters/version_control/null_repo.rb +18 -18
- data/app/adapters/houston/adapters.rb +10 -10
- data/app/assets/javascripts/app/boot.coffee +5 -5
- data/app/assets/javascripts/app/infinite_scroll.coffee +6 -6
- data/app/assets/javascripts/app/models/commit.coffee +1 -1
- data/app/assets/javascripts/app/models/release.coffee +1 -1
- data/app/assets/javascripts/app/models/task.coffee +1 -1
- data/app/assets/javascripts/app/models/tester.coffee +1 -1
- data/app/assets/javascripts/app/models/testing_note.coffee +2 -2
- data/app/assets/javascripts/app/models/ticket.coffee +24 -24
- data/app/assets/javascripts/app/models/user.coffee +1 -1
- data/app/assets/javascripts/app/releases.coffee +6 -6
- data/app/assets/javascripts/app/stacked_area_graph.coffee +22 -22
- data/app/assets/javascripts/app/stacked_bar_graph.coffee +20 -20
- data/app/assets/javascripts/app/table_row_expander.coffee +10 -10
- data/app/assets/javascripts/app/ticket_tracker_refresh.coffee +19 -19
- data/app/assets/javascripts/app/views/_show_sprint_view.coffee +14 -14
- data/app/assets/javascripts/app/views/_tickets_view.coffee +8 -8
- data/app/assets/javascripts/app/views/all_tickets_view.coffee +1 -2
- data/app/assets/javascripts/app/views/commit_view.coffee +2 -2
- data/app/assets/javascripts/app/views/edit_sprint_view.coffee +36 -36
- data/app/assets/javascripts/app/views/find_or_create_ticket_view.coffee +3 -3
- data/app/assets/javascripts/app/views/keyboard_shortcuts_modal.coffee +14 -14
- data/app/assets/javascripts/app/views/new_ticket_modal.coffee +4 -4
- data/app/assets/javascripts/app/views/new_ticket_view.coffee +34 -34
- data/app/assets/javascripts/app/views/problems_view.coffee +8 -8
- data/app/assets/javascripts/app/views/reports_view.coffee +5 -5
- data/app/assets/javascripts/app/views/testing_note_view.coffee +10 -10
- data/app/assets/javascripts/app/views/testing_report_view.coffee +7 -7
- data/app/assets/javascripts/app/views/testing_ticket_view.coffee +36 -36
- data/app/assets/javascripts/app/views/ticket_modal_view.coffee +5 -5
- data/app/assets/javascripts/core/app.coffee +22 -22
- data/app/assets/javascripts/core/burndown_chart.coffee +21 -21
- data/app/assets/javascripts/core/errors.coffee +2 -2
- data/app/assets/javascripts/core/handlebars_helpers.coffee +6 -6
- data/app/assets/javascripts/core/jquery_extensions.coffee +28 -28
- data/app/assets/javascripts/dashboard/refresher.coffee +4 -4
- data/app/assets/stylesheets/application/ansi.scss +2 -2
- data/app/assets/stylesheets/application/commit.scss +1 -1
- data/app/assets/stylesheets/application/exceptions.scss +3 -3
- data/app/assets/stylesheets/application/find_or_create_ticket.scss +2 -2
- data/app/assets/stylesheets/application/follow_up.scss +2 -2
- data/app/assets/stylesheets/application/forms.scss +2 -2
- data/app/assets/stylesheets/application/freight_train.css.scss +5 -5
- data/app/assets/stylesheets/application/full_screen.scss +2 -2
- data/app/assets/stylesheets/application/infinite_scroll.scss +1 -1
- data/app/assets/stylesheets/application/keyboard_shortcuts.scss +3 -3
- data/app/assets/stylesheets/application/markdown.scss +2 -2
- data/app/assets/stylesheets/application/navigation.scss +15 -15
- data/app/assets/stylesheets/application/new_ticket_view.scss +16 -16
- data/app/assets/stylesheets/application/omnibar.scss +6 -6
- data/app/assets/stylesheets/application/project_banner_buttons.scss +6 -6
- data/app/assets/stylesheets/application/project_tiles.scss +2 -2
- data/app/assets/stylesheets/application/projects.css.scss +3 -3
- data/app/assets/stylesheets/application/pull_requests.scss +6 -6
- data/app/assets/stylesheets/application/queue.scss +2 -2
- data/app/assets/stylesheets/application/release_form.scss +10 -10
- data/app/assets/stylesheets/application/releases.scss +32 -39
- data/app/assets/stylesheets/application/sortable_table.scss +6 -6
- data/app/assets/stylesheets/application/sprint.scss +6 -6
- data/app/assets/stylesheets/application/tables.scss +6 -6
- data/app/assets/stylesheets/application/test_run.scss +16 -16
- data/app/assets/stylesheets/application/ticket.scss +13 -13
- data/app/assets/stylesheets/application/ticket_modal.scss +19 -19
- data/app/assets/stylesheets/application/tickets.scss +2 -2
- data/app/assets/stylesheets/application/timeline.scss +30 -30
- data/app/assets/stylesheets/application/tips.scss +1 -1
- data/app/assets/stylesheets/application/typeahead.scss +4 -4
- data/app/assets/stylesheets/application/uploading.scss +13 -13
- data/app/assets/stylesheets/application/welcome.scss +3 -3
- data/app/assets/stylesheets/core/burndown_chart.scss +11 -11
- data/app/assets/stylesheets/core/misc.scss +8 -8
- data/app/assets/stylesheets/core/overrides.scss +2 -2
- data/app/assets/stylesheets/core/scores.scss +26 -26
- data/app/assets/stylesheets/dashboard/dashboard.scss +16 -16
- data/app/assets/stylesheets/print.css.scss +3 -3
- data/app/concerns/commit_synchronizer.rb +24 -24
- data/app/concerns/feature_state.rb +7 -7
- data/app/concerns/feature_support.rb +4 -4
- data/app/concerns/historical_weekly_stats.rb +4 -4
- data/app/concerns/milestone_synchronizer.rb +14 -14
- data/app/concerns/nosync.rb +4 -4
- data/app/concerns/project_adapter.rb +22 -22
- data/app/concerns/retirement.rb +7 -7
- data/app/concerns/ticket_synchronizer.rb +31 -31
- data/app/concerns/unique_add.rb +2 -2
- data/app/controllers/api/v1/sprint_tasks_controller.rb +19 -19
- data/app/controllers/api/v1/ticket_tasks_controller.rb +14 -14
- data/app/controllers/application_controller.rb +46 -40
- data/app/controllers/commits_controller.rb +10 -10
- data/app/controllers/deploys_controller.rb +11 -11
- data/app/controllers/home_controller.rb +4 -4
- data/app/controllers/jobs_controller.rb +3 -3
- data/app/controllers/oauth_consumers_controller.rb +1 -1
- data/app/controllers/omnibar_controller.rb +6 -6
- data/app/controllers/project_exceptions_controller.rb +11 -11
- data/app/controllers/project_hooks_controller.rb +7 -7
- data/app/controllers/project_options_controller.rb +8 -8
- data/app/controllers/project_pretickets_controller.rb +6 -6
- data/app/controllers/project_roles_controller.rb +7 -7
- data/app/controllers/project_tickets_controller.rb +28 -28
- data/app/controllers/project_tickets_sync_controller.rb +8 -8
- data/app/controllers/projects_controller.rb +29 -29
- data/app/controllers/releases_controller.rb +25 -25
- data/app/controllers/reports_controller.rb +36 -36
- data/app/controllers/sessions_controller.rb +2 -2
- data/app/controllers/settings_controller.rb +3 -3
- data/app/controllers/sprint_task_locks_controller.rb +11 -11
- data/app/controllers/sprints_controller.rb +25 -25
- data/app/controllers/tasks_controller.rb +10 -10
- data/app/controllers/test_runs_controller.rb +8 -8
- data/app/controllers/tester_bar_controller.rb +2 -2
- data/app/controllers/testing_notes_controller.rb +15 -15
- data/app/controllers/testing_report_controller.rb +14 -14
- data/app/controllers/tickets_controller.rb +9 -9
- data/app/controllers/uploads_controller.rb +9 -9
- data/app/controllers/user_credentials_controller.rb +4 -4
- data/app/controllers/user_options_controller.rb +6 -6
- data/app/controllers/users_controller.rb +34 -34
- data/app/controllers/welcome_controller.rb +6 -6
- data/app/helpers/ansi_helper.rb +4 -4
- data/app/helpers/application_helper.rb +26 -26
- data/app/helpers/avatar_helper.rb +12 -12
- data/app/helpers/backtrace_helper.rb +2 -2
- data/app/helpers/breadcrumbs_helper.rb +9 -9
- data/app/helpers/commit_helper.rb +16 -12
- data/app/helpers/demo_helper.rb +4 -4
- data/app/helpers/email_helper.rb +3 -3
- data/app/helpers/emoji_helper.rb +1 -1
- data/app/helpers/excel_helpers.rb +2 -2
- data/app/helpers/exposure_helper.rb +3 -3
- data/app/helpers/flash_message_helper.rb +6 -6
- data/app/helpers/maintenance_light_helper.rb +3 -3
- data/app/helpers/markdown_helper.rb +3 -3
- data/app/helpers/navigation_helper.rb +12 -12
- data/app/helpers/project_helper.rb +5 -5
- data/app/helpers/release_helper.rb +9 -9
- data/app/helpers/score_card_helper.rb +16 -16
- data/app/helpers/sprint_helper.rb +2 -2
- data/app/helpers/static_chart_helper.rb +2 -2
- data/app/helpers/test_run_helper.rb +6 -6
- data/app/helpers/ticket_helper.rb +14 -14
- data/app/helpers/timeline_helper.rb +5 -5
- data/app/helpers/url_helper.rb +26 -26
- data/app/helpers/user_helper.rb +6 -6
- data/app/helpers/version_helper.rb +4 -4
- data/app/interactors/test_run_comparer.rb +9 -9
- data/app/interactors/ticket_report.rb +7 -7
- data/app/jobs/sync_all_tickets_job.rb +13 -13
- data/app/jobs/sync_commits_job.rb +3 -3
- data/app/jobs/sync_project_tickets_job.rb +9 -9
- data/app/mailers/deploy_notification.rb +9 -9
- data/app/mailers/project_notification.rb +29 -29
- data/app/mailers/view_mailer.rb +20 -38
- data/app/models/ability.rb +21 -21
- data/app/models/activity_feed.rb +25 -25
- data/app/models/antecedent.rb +3 -3
- data/app/models/code_climate/coverage_report.rb +25 -25
- data/app/models/commit.rb +77 -82
- data/app/models/consumer_token.rb +2 -2
- data/app/models/deploy.rb +31 -27
- data/app/models/environment.rb +12 -12
- data/app/models/github/commit_status_report.rb +16 -16
- data/app/models/github/pull_request.rb +35 -12
- data/app/models/github/pull_request_event.rb +6 -5
- data/app/models/github_token.rb +2 -2
- data/app/models/historical_head.rb +2 -2
- data/app/models/key_dependency.rb +17 -17
- data/app/models/maintenance_light.rb +3 -3
- data/app/models/measurement.rb +22 -22
- data/app/models/menu_item.rb +5 -5
- data/app/models/menu_item_divider.rb +1 -1
- data/app/models/milestone.rb +27 -27
- data/app/models/output_stream.rb +4 -4
- data/app/models/post_receive_payload.rb +7 -7
- data/app/models/project.rb +93 -89
- data/app/models/project_dependencies.rb +9 -9
- data/app/models/project_dependency.rb +33 -33
- data/app/models/project_menu_item.rb +3 -3
- data/app/models/release.rb +60 -60
- data/app/models/release_change.rb +18 -18
- data/app/models/role.rb +15 -15
- data/app/models/rubygems/gem.rb +21 -21
- data/app/models/run_tests_on_post_receive.rb +36 -36
- data/app/models/setting.rb +3 -3
- data/app/models/settings.rb +8 -8
- data/app/models/source_file_coverage.rb +2 -2
- data/app/models/sprint.rb +19 -19
- data/app/models/sprint_report.rb +7 -7
- data/app/models/sprint_task.rb +8 -8
- data/app/models/static_chart/area.rb +19 -19
- data/app/models/static_chart.rb +35 -35
- data/app/models/task.rb +64 -64
- data/app/models/test_error.rb +2 -2
- data/app/models/test_result.rb +7 -0
- data/app/models/test_run.rb +75 -79
- data/app/models/test_run_statistics.rb +18 -19
- data/app/models/testing_note.rb +19 -19
- data/app/models/ticket.rb +104 -104
- data/app/models/ticket_antecedent.rb +11 -11
- data/app/models/ticket_comment.rb +6 -6
- data/app/models/ticket_committer.rb +3 -3
- data/app/models/ticket_tag.rb +6 -6
- data/app/models/user.rb +44 -44
- data/app/models/user_credentials.rb +11 -11
- data/app/models/value_statement.rb +3 -3
- data/app/presenters/commit_presenter.rb +6 -6
- data/app/presenters/one_or_many.rb +4 -4
- data/app/presenters/problem_presenter.rb +8 -8
- data/app/presenters/release_presenter.rb +4 -4
- data/app/presenters/sprint_task_presenter.rb +9 -9
- data/app/presenters/task_presenter.rb +8 -8
- data/app/presenters/tasks_excel_presenter.rb +6 -6
- data/app/presenters/tester_presenter.rb +3 -3
- data/app/presenters/testing_note_presenter.rb +4 -4
- data/app/presenters/testing_report_ticket_presenter.rb +9 -9
- data/app/presenters/ticket_presenter.rb +4 -4
- data/app/views/deploys/show.html.erb +8 -0
- data/app/views/jobs/show.html.erb +0 -34
- data/app/views/layouts/application.html.erb +1 -0
- data/app/views/layouts/minimal.html.erb +1 -0
- data/app/views/projects/_form.html.erb +0 -7
- data/app/views/releases/_form.html.erb +9 -3
- data/app/views/releases/index.html.erb +1 -1
- data/config/application.rb +1 -2
- data/config/database.yml +3 -3
- data/config/environments/production.rb +1 -1
- data/config/environments/test.rb +1 -1
- data/config/initializers/action_view_field_error_proc.rb +3 -3
- data/config/initializers/constants.rb +3 -3
- data/config/initializers/devise.rb +8 -8
- data/config/initializers/hard_coded_knowledge.rb +3 -3
- data/config/initializers/houston_async.rb +2 -2
- data/config/initializers/houston_report_exception.rb +3 -3
- data/config/initializers/houston_try.rb +3 -3
- data/config/initializers/sync_commits_on_post_receive.rb +0 -5
- data/config/routes.rb +108 -108
- data/db/migrate/20120417175450_devise_create_users.rb +2 -2
- data/db/migrate/20120501230243_add_unfuddle_id_to_tickets.rb +1 -1
- data/db/migrate/20120504143615_link_tickets_and_releases.rb +3 -3
- data/db/migrate/20120626150333_add_last_release_at_to_tickets.rb +2 -2
- data/db/migrate/20120626151320_link_tickets_and_commits.rb +2 -2
- data/db/migrate/20120626152020_add_committer_email_to_commits.rb +2 -2
- data/db/migrate/20120715230922_create_user_notifications.rb +3 -3
- data/db/migrate/20120716010743_add_user_to_releases.rb +3 -3
- data/db/migrate/20120726231754_link_projects_and_maintainers.rb +2 -2
- data/db/migrate/20120826022643_add_authentication_token_to_users.rb +2 -2
- data/db/migrate/20120920023251_add_administrator_to_users.rb +3 -3
- data/db/migrate/20121026014457_split_users_name_into_first_and_last.rb +2 -2
- data/db/migrate/20121027160548_create_deploys.rb +1 -1
- data/db/migrate/20121222170917_add_version_control_adapter_to_projects.rb +2 -2
- data/db/migrate/20121222223635_add_ticket_tracking_adapter_to_projects.rb +2 -2
- data/db/migrate/20121224212623_rename_environments.rb +3 -3
- data/db/migrate/20121225175106_replace_environment_id_with_environment_name.rb +8 -8
- data/db/migrate/20121230174234_create_test_runs.rb +3 -3
- data/db/migrate/20130119203853_remove_cached_queries_from_projects.rb +1 -1
- data/db/migrate/20130119204608_add_extended_attributes_to_tickets.rb +10 -10
- data/db/migrate/20130120182026_create_ticket_prerequisites.rb +2 -2
- data/db/migrate/20130312224911_create_errors.rb +1 -1
- data/db/migrate/20130407195450_create_roles.rb +2 -2
- data/db/migrate/20130407200624_populate_roles.rb +9 -9
- data/db/migrate/20130407220039_add_project_id_to_testing_notes.rb +6 -6
- data/db/migrate/20130407220937_add_project_id_to_commits.rb +6 -6
- data/db/migrate/20130416020627_add_environments_subscribed_to_to_users.rb +3 -3
- data/db/migrate/20130420174126_add_error_tracker_name_to_projects.rb +2 -2
- data/db/migrate/20130427223925_create_project_quotas.rb +2 -2
- data/db/migrate/20130504014802_add_extended_attributes_to_projects.rb +3 -3
- data/db/migrate/20130504135741_add_antecedents_to_tickets.rb +6 -6
- data/db/migrate/20130505144446_add_tags_to_tickets.rb +1 -1
- data/db/migrate/20130505162039_add_type_to_tickets.rb +1 -1
- data/db/migrate/20130505212838_add_closed_at_to_tickets.rb +1 -1
- data/db/migrate/20130519163615_create_user_credentials.rb +2 -2
- data/db/migrate/20130526024851_give_default_values_for_counts_from_test_runs.rb +2 -2
- data/db/migrate/20130710233849_add_authored_at_to_commits.rb +10 -10
- data/db/migrate/20130711013156_link_commits_and_users.rb +6 -6
- data/db/migrate/20130806143651_link_commits_and_releases.rb +2 -2
- data/db/migrate/20130921141449_create_milestones.rb +3 -3
- data/db/migrate/20131004185618_add_first_release_at_to_tickets.rb +2 -2
- data/db/migrate/20131012152403_create_sprints.rb +3 -3
- data/db/migrate/20131112010815_delete_duplicate_commits.rb +7 -7
- data/db/migrate/20140217160450_add_email_addresses_to_users.rb +3 -3
- data/db/migrate/20140327020121_drop_ticket_prerequisites.rb +1 -1
- data/db/migrate/20140406183224_remove_new_relic_id_from_projects.rb +1 -1
- data/db/migrate/20140406230121_delete_automatically_generated_messages_for_releases.rb +1 -1
- data/db/migrate/20140407010111_drop_sprints_project_id.rb +1 -1
- data/db/migrate/20140418133005_change_ticket_antecedents_to_text_array.rb +1 -1
- data/db/migrate/20140425141946_embed_changes_in_releases.rb +3 -3
- data/db/migrate/20140515174322_create_tasks.rb +3 -3
- data/db/migrate/20140516012049_create_tasks_for_existing_tickets.rb +1 -1
- data/db/migrate/20140517012626_prevent_hstore_fields_from_being_null.rb +2 -2
- data/db/migrate/20140521014652_allow_task_descriptions_to_be_null.rb +1 -1
- data/db/migrate/20140526155845_add_commit_id_to_deploys.rb +5 -5
- data/db/migrate/20140526162645_add_commit_before_id_and_commit_after_id_to_releases.rb +4 -4
- data/db/migrate/20140526180608_associate_remaining_deploys_and_releases.rb +12 -12
- data/db/migrate/20140724231918_create_sprints_tasks.rb +3 -3
- data/db/migrate/20140824194031_add_project_id_to_tasks.rb +1 -1
- data/db/migrate/20140824194526_add_completed_at_to_tasks.rb +3 -3
- data/db/migrate/20140824211249_require_sprints_to_be_unique.rb +1 -1
- data/db/migrate/20140907012329_drop_table_changes.rb +1 -1
- data/db/migrate/20140907013836_drop_table_errors.rb +1 -1
- data/db/migrate/20140921190022_add_checked_out_to_sprints_tasks.rb +2 -2
- data/db/migrate/20140921201441_drop_users_name.rb +1 -1
- data/db/migrate/20140925021043_rename_deploys_commit_to_sha.rb +1 -1
- data/db/migrate/20140929004347_create_historical_heads.rb +4 -4
- data/db/migrate/20141027194819_make_users_environments_subscribed_to_an_array.rb +2 -2
- data/db/migrate/20141226171730_create_measurements.rb +1 -1
- data/db/migrate/20150119154013_drop_unused_fields_from_milestones.rb +1 -1
- data/db/migrate/20150222205616_add_features_to_projects.rb +2 -2
- data/db/migrate/20150323004452_add_deploys_completed_at.rb +1 -1
- data/db/migrate/20150805180939_add_commit_id_to_test_runs.rb +1 -1
- data/db/migrate/20150808161805_create_test_results.rb +1 -1
- data/db/migrate/20150809132417_rename_test_results_regression_to_difference.rb +1 -1
- data/db/migrate/20150927014445_required_pull_requests_to_be_unique_by_project_and_number.rb +13 -0
- data/db/structure.sql +9 -0
- data/houston.gemspec +23 -26
- data/lib/configuration.rb +0 -5
- data/lib/core_ext/duration.rb +4 -4
- data/lib/core_ext/hash.rb +17 -17
- data/lib/houston/version.rb +1 -1
- data/lib/houston_server.rb +6 -6
- data/lib/parallel_enumerable.rb +16 -16
- data/lib/tasks/specific_tests.rake +37 -0
- metadata +91 -107
- data/app/interactors/push_gemfile_to_gemnasium.rb +0 -88
- data/app/models/gemnasium/alert.rb +0 -25
- data/app/views/welcome/_tdl.html.erb +0 -31
- data/config/initializers/houston_tdl.rb +0 -104
@@ -2,39 +2,39 @@ class ReleasesController < ApplicationController
|
|
2
2
|
include UrlHelper
|
3
3
|
before_filter :get_project_and_environment
|
4
4
|
before_filter :load_tickets, only: [:new, :edit, :create, :update]
|
5
|
-
|
5
|
+
|
6
6
|
def index
|
7
7
|
@title = "Releases • #{@project.name}"
|
8
8
|
@title << " (#{@environment})" if @environment
|
9
9
|
end
|
10
|
-
|
10
|
+
|
11
11
|
def show
|
12
12
|
@release = @releases.find(params[:id])
|
13
13
|
authorize! :show, @release
|
14
|
-
|
14
|
+
|
15
15
|
@title = "Release #{@release.release_date.strftime("%b %-d")} • #{@project.name}"
|
16
16
|
end
|
17
|
-
|
17
|
+
|
18
18
|
def new
|
19
19
|
@title = "New Release (#{@environment}) • #{@project.name}"
|
20
|
-
|
20
|
+
|
21
21
|
@deploy = Deploy.find_by_id(params[:deploy_id])
|
22
22
|
@releases = @releases.before(@deploy.completed_at) if @deploy
|
23
23
|
@commit0 = params.fetch :commit0, @releases.most_recent_commit
|
24
24
|
@commit1 = params.fetch :commit1, @deploy.try(:commit)
|
25
25
|
@release = @releases.new(commit0: @commit0, commit1: @commit1, deploy: @deploy)
|
26
26
|
authorize! :create, @release
|
27
|
-
|
27
|
+
|
28
28
|
@manual = params[:manual] == "true" || !@project.has_version_control?
|
29
|
-
|
29
|
+
|
30
30
|
if @release.can_read_commits?
|
31
31
|
@release.load_commits!
|
32
32
|
@release.load_tickets!
|
33
33
|
@release.build_changes_from_commits
|
34
34
|
end
|
35
|
-
|
35
|
+
|
36
36
|
@release.release_changes = [ReleaseChange.new(@release, "", "")] if @release.release_changes.none?
|
37
|
-
|
37
|
+
|
38
38
|
if request.headers["X-PJAX"]
|
39
39
|
render template: "releases/_new_release", layout: false
|
40
40
|
else
|
@@ -45,7 +45,7 @@ class ReleasesController < ApplicationController
|
|
45
45
|
def edit
|
46
46
|
@release = @releases.find(params[:id])
|
47
47
|
authorize! :update, @release
|
48
|
-
|
48
|
+
|
49
49
|
if params[:recreate]
|
50
50
|
if @release.can_read_commits?
|
51
51
|
@release.load_commits!
|
@@ -53,7 +53,7 @@ class ReleasesController < ApplicationController
|
|
53
53
|
@release.build_changes_from_commits
|
54
54
|
end
|
55
55
|
end
|
56
|
-
|
56
|
+
|
57
57
|
@release.release_changes = [ReleaseChange.new(@release, "", "")] if @release.release_changes.none?
|
58
58
|
@release.valid?
|
59
59
|
end
|
@@ -62,50 +62,50 @@ class ReleasesController < ApplicationController
|
|
62
62
|
@release = @releases.new(params[:release])
|
63
63
|
@release.user = current_user
|
64
64
|
authorize! :create, @release
|
65
|
-
|
65
|
+
|
66
66
|
if @release.save
|
67
67
|
ProjectNotification.release(@release).deliver! if params[:send_release_email]
|
68
68
|
@release.tickets.resolve_all! if params[:resolve_tickets]
|
69
|
-
|
69
|
+
|
70
70
|
redirect_to @release
|
71
71
|
else
|
72
72
|
@commit0 = @release.commit0
|
73
73
|
@commit1 = @release.commit1
|
74
|
-
|
74
|
+
|
75
75
|
if @release.can_read_commits?
|
76
76
|
@release.load_commits!
|
77
77
|
@release.load_tickets!
|
78
78
|
end
|
79
|
-
|
79
|
+
|
80
80
|
render action: "new"
|
81
81
|
end
|
82
82
|
end
|
83
|
-
|
83
|
+
|
84
84
|
def update
|
85
85
|
@release = @releases.find(params[:id])
|
86
86
|
authorize! :update, @release
|
87
|
-
|
87
|
+
|
88
88
|
if @release.update_attributes(params[:release])
|
89
89
|
redirect_to @release, notice: "Release was successfully updated."
|
90
90
|
else
|
91
91
|
render action: "edit"
|
92
92
|
end
|
93
93
|
end
|
94
|
-
|
94
|
+
|
95
95
|
def destroy
|
96
96
|
@release = @releases.find(params[:id])
|
97
97
|
authorize! :destroy, @release
|
98
|
-
|
98
|
+
|
99
99
|
@release.destroy
|
100
|
-
|
100
|
+
|
101
101
|
redirect_to releases_url
|
102
102
|
end
|
103
|
-
|
103
|
+
|
104
104
|
private
|
105
|
-
|
105
|
+
|
106
106
|
def get_project_and_environment
|
107
107
|
@project = Project.find_by_slug!(params[:project_id])
|
108
|
-
@environment = params[:environment] || @project.
|
108
|
+
@environment = params[:environment] || @project.environments_with_release_notes.first
|
109
109
|
@deploys = @project.deploys
|
110
110
|
.completed
|
111
111
|
.to(@environment)
|
@@ -116,7 +116,7 @@ private
|
|
116
116
|
.includes(:project)
|
117
117
|
.includes(:deploy)
|
118
118
|
end
|
119
|
-
|
119
|
+
|
120
120
|
def load_tickets
|
121
121
|
@tickets = @project.tickets.includes(:project).map do |ticket|
|
122
122
|
{ id: ticket.id,
|
@@ -126,5 +126,5 @@ private
|
|
126
126
|
number: ticket.number }
|
127
127
|
end
|
128
128
|
end
|
129
|
-
|
129
|
+
|
130
130
|
end
|
@@ -2,13 +2,13 @@ class ReportsController < ApplicationController
|
|
2
2
|
before_filter { authorize! :read, :reports }
|
3
3
|
before_filter :find_tickets, only: [:queue_age, :cycle_time, :time_to_first_test, :time_to_release]
|
4
4
|
layout "minimal"
|
5
|
-
|
5
|
+
|
6
6
|
attr_reader :tickets, :start_date, :end_date
|
7
|
-
|
7
|
+
|
8
8
|
def index
|
9
9
|
@title = "Reports"
|
10
10
|
end
|
11
|
-
|
11
|
+
|
12
12
|
def queue_age
|
13
13
|
results = benchmark("pluck") do
|
14
14
|
tickets.joins(<<-SQL)
|
@@ -20,13 +20,13 @@ class ReportsController < ApplicationController
|
|
20
20
|
.reorder("months.month ASC")
|
21
21
|
.pluck("months.month::date", "extract('epoch' from month - tickets.created_at)")
|
22
22
|
end
|
23
|
-
|
23
|
+
|
24
24
|
results = benchmark("process") do
|
25
25
|
results \
|
26
26
|
.each_with_object(Hash.new { |h, k| h[k] = [] }) { |(date, age), map| map[date].push(age) }
|
27
27
|
.map { |date, ages| [date] + to_age_bins(ages) }
|
28
28
|
end
|
29
|
-
|
29
|
+
|
30
30
|
line = benchmark("line") do
|
31
31
|
tickets.closed
|
32
32
|
.group("date_trunc('month', closed_at)::date")
|
@@ -34,12 +34,12 @@ class ReportsController < ApplicationController
|
|
34
34
|
.pluck("date_trunc('month', closed_at)::date", "COUNT(id)")
|
35
35
|
.map { |(month, count)| {date: month, y: count} }
|
36
36
|
end
|
37
|
-
|
37
|
+
|
38
38
|
benchmark("present") do
|
39
39
|
render json: {data: results, line: line}
|
40
40
|
end
|
41
41
|
end
|
42
|
-
|
42
|
+
|
43
43
|
def cycle_time
|
44
44
|
results = benchmark("pluck") do
|
45
45
|
tickets.joins(<<-SQL)
|
@@ -52,12 +52,12 @@ class ReportsController < ApplicationController
|
|
52
52
|
.reorder("months.month ASC")
|
53
53
|
.pluck("months.month::date", "AVG(extract('epoch' from month - tickets.created_at)) / 86400")
|
54
54
|
end
|
55
|
-
|
55
|
+
|
56
56
|
benchmark("present") do
|
57
57
|
render json: results
|
58
58
|
end
|
59
59
|
end
|
60
|
-
|
60
|
+
|
61
61
|
def time_to_release
|
62
62
|
results = benchmark("pluck") do
|
63
63
|
Ticket.connection.select_rows(<<-SQL)
|
@@ -72,7 +72,7 @@ class ReportsController < ApplicationController
|
|
72
72
|
tickets.closed_at,
|
73
73
|
to_production.created_at "released_at"
|
74
74
|
FROM tickets
|
75
|
-
|
75
|
+
|
76
76
|
INNER JOIN (
|
77
77
|
SELECT rt1.ticket_id, MIN(r1.created_at) "created_at"
|
78
78
|
FROM releases r1
|
@@ -80,7 +80,7 @@ class ReportsController < ApplicationController
|
|
80
80
|
WHERE r1.environment_name = 'Staging'
|
81
81
|
GROUP BY rt1.ticket_id
|
82
82
|
) AS to_staging ON to_staging.ticket_id=tickets.id
|
83
|
-
|
83
|
+
|
84
84
|
INNER JOIN (
|
85
85
|
SELECT rt2.ticket_id, MIN(r2.created_at) "created_at"
|
86
86
|
FROM releases r2
|
@@ -88,7 +88,7 @@ class ReportsController < ApplicationController
|
|
88
88
|
WHERE r2.environment_name = 'Production'
|
89
89
|
GROUP BY rt2.ticket_id
|
90
90
|
) AS to_production ON to_production.ticket_id=tickets.id
|
91
|
-
|
91
|
+
|
92
92
|
) AS q
|
93
93
|
ON q.released_at >= months.month
|
94
94
|
AND q.released_at < (months.month + interval '1 month')
|
@@ -99,12 +99,12 @@ class ReportsController < ApplicationController
|
|
99
99
|
SQL
|
100
100
|
.map { |(date, v1, v2, v3)| [date.to_date, v1.to_i, v2.to_i, v3.to_i] }
|
101
101
|
end
|
102
|
-
|
102
|
+
|
103
103
|
benchmark("present") do
|
104
104
|
render json: results
|
105
105
|
end
|
106
106
|
end
|
107
|
-
|
107
|
+
|
108
108
|
def time_to_first_test
|
109
109
|
results = benchmark("pluck") do
|
110
110
|
Ticket.connection.select_rows(<<-SQL)
|
@@ -117,7 +117,7 @@ class ReportsController < ApplicationController
|
|
117
117
|
to_staging.created_at "to_staging_at",
|
118
118
|
first_test.created_at "testing_started_at"
|
119
119
|
FROM tickets
|
120
|
-
|
120
|
+
|
121
121
|
INNER JOIN (
|
122
122
|
SELECT rt1.ticket_id, MIN(r1.created_at) "created_at"
|
123
123
|
FROM releases r1
|
@@ -125,13 +125,13 @@ class ReportsController < ApplicationController
|
|
125
125
|
WHERE r1.environment_name = 'Staging'
|
126
126
|
GROUP BY rt1.ticket_id
|
127
127
|
) AS to_staging ON to_staging.ticket_id=tickets.id
|
128
|
-
|
128
|
+
|
129
129
|
INNER JOIN (
|
130
130
|
SELECT tn.ticket_id, MIN(tn.created_at) "created_at"
|
131
131
|
FROM testing_notes tn
|
132
132
|
GROUP BY tn.ticket_id
|
133
133
|
) AS first_test ON first_test.ticket_id=tickets.id
|
134
|
-
|
134
|
+
|
135
135
|
) AS q
|
136
136
|
ON q.to_staging_at >= months.month
|
137
137
|
AND q.to_staging_at < (months.month + interval '1 month')
|
@@ -141,30 +141,30 @@ class ReportsController < ApplicationController
|
|
141
141
|
SQL
|
142
142
|
.map { |(date, v1, v2, v3)| [date.to_date, v1.to_i, v2.to_i, v3.to_i] }
|
143
143
|
end
|
144
|
-
|
144
|
+
|
145
145
|
benchmark("present") do
|
146
146
|
render json: results
|
147
147
|
end
|
148
148
|
end
|
149
|
-
|
150
|
-
|
151
|
-
|
149
|
+
|
150
|
+
|
151
|
+
|
152
152
|
def velocity
|
153
153
|
@title = "Reports"
|
154
154
|
@tickets = ::Ticket.includes(:project, :tasks).estimated.closed
|
155
155
|
.select { |ticket| ticket.commit_time > 0 } # <-- speed up
|
156
156
|
end
|
157
|
-
|
157
|
+
|
158
158
|
def sprint
|
159
159
|
@title = "Sprint Reports"
|
160
160
|
@start_date = Date.parse(params.fetch(:since, "2014-05-18")) # when tasks were added
|
161
161
|
@start_date = Date.parse(params.fetch(:since, "2014-08-07"))
|
162
162
|
@end_date = Date.today
|
163
|
-
|
163
|
+
|
164
164
|
@users = []
|
165
165
|
([nil] + User.developers).each do |user|
|
166
166
|
data = SprintReport.new(user, start_date, end_date).to_a
|
167
|
-
|
167
|
+
|
168
168
|
next if data.all? { |(_, completed, missed)| (completed + missed).zero? }
|
169
169
|
average = data
|
170
170
|
.select { |_, completed, missed| (completed + missed) > 0 }
|
@@ -173,9 +173,9 @@ class ReportsController < ApplicationController
|
|
173
173
|
end
|
174
174
|
@users.sort_by! { |(_, average, _)| -average }
|
175
175
|
end
|
176
|
-
|
177
|
-
|
178
|
-
|
176
|
+
|
177
|
+
|
178
|
+
|
179
179
|
def tasks_excel
|
180
180
|
authorize! :read, "Report"
|
181
181
|
tasks = Task.completed
|
@@ -184,32 +184,32 @@ class ReportsController < ApplicationController
|
|
184
184
|
filename: "Tasks.xlsx",
|
185
185
|
disposition: "attachment"
|
186
186
|
end
|
187
|
-
|
188
|
-
|
189
|
-
|
187
|
+
|
188
|
+
|
189
|
+
|
190
190
|
private
|
191
|
-
|
191
|
+
|
192
192
|
CUTOFFS = [3.weeks, 3.months, 9.months, 2.years, 99.years].freeze
|
193
|
-
|
193
|
+
|
194
194
|
def to_age_bins(ages)
|
195
195
|
ages.each_with_object([0, 0, 0, 0, 0]) do |age, bins|
|
196
196
|
bins[to_bin(age)] += 1
|
197
197
|
end
|
198
198
|
end
|
199
|
-
|
199
|
+
|
200
200
|
def to_bin(age)
|
201
201
|
CUTOFFS.each_with_index do |cutoff, i|
|
202
202
|
return i if age < cutoff
|
203
203
|
end
|
204
204
|
end
|
205
|
-
|
205
|
+
|
206
206
|
def find_tickets
|
207
207
|
@tickets = Ticket.reorder(:created_at)
|
208
208
|
@tickets = tickets.where(project_id: params[:project_id]) if params[:project_id]
|
209
209
|
@tickets = tickets.where(project_id: params[:projects].split(",")) if params[:projects]
|
210
|
-
|
210
|
+
|
211
211
|
@start_date = params.fetch(:since, "2010-01-01")
|
212
212
|
@end_date = Date.today.strftime "%Y-%m-%d"
|
213
213
|
end
|
214
|
-
|
214
|
+
|
215
215
|
end
|
@@ -1,14 +1,14 @@
|
|
1
1
|
class SettingsController < ApplicationController
|
2
2
|
load_and_authorize_resource
|
3
|
-
|
3
|
+
|
4
4
|
def show
|
5
5
|
@settings = Settings.new
|
6
6
|
end
|
7
|
-
|
7
|
+
|
8
8
|
def update
|
9
9
|
@settings = Settings.new(params[:settings])
|
10
10
|
@settings.save!
|
11
11
|
redirect_to settings_path, :notice => "Changes saved"
|
12
12
|
end
|
13
|
-
|
13
|
+
|
14
14
|
end
|
@@ -1,16 +1,16 @@
|
|
1
1
|
class SprintTaskLocksController < ApplicationController
|
2
2
|
before_filter :authenticate_user!
|
3
3
|
before_filter :find_sprint_and_task
|
4
|
-
|
4
|
+
|
5
5
|
attr_reader :sprint, :task
|
6
|
-
|
7
|
-
|
6
|
+
|
7
|
+
|
8
8
|
def create
|
9
9
|
if sprint.completed?
|
10
10
|
render json: {base: ["The Sprint is completed. You cannot check out or check in tasks."]}, status: :unprocessable_entity
|
11
11
|
return
|
12
12
|
end
|
13
|
-
|
13
|
+
|
14
14
|
if task.checked_out?(sprint)
|
15
15
|
render json: {base: ["Task ##{task.shorthand} is already checked out"]}, status: 422
|
16
16
|
else
|
@@ -18,14 +18,14 @@ class SprintTaskLocksController < ApplicationController
|
|
18
18
|
head :ok
|
19
19
|
end
|
20
20
|
end
|
21
|
-
|
22
|
-
|
21
|
+
|
22
|
+
|
23
23
|
def destroy
|
24
24
|
if sprint.completed?
|
25
25
|
render json: {base: ["The Sprint is completed. You cannot check out or check in tasks."]}, status: :unprocessable_entity
|
26
26
|
return
|
27
27
|
end
|
28
|
-
|
28
|
+
|
29
29
|
if task.checked_out_by_me?(sprint, current_user)
|
30
30
|
task.check_in!(sprint)
|
31
31
|
head :ok
|
@@ -35,13 +35,13 @@ class SprintTaskLocksController < ApplicationController
|
|
35
35
|
head :ok
|
36
36
|
end
|
37
37
|
end
|
38
|
-
|
39
|
-
|
38
|
+
|
39
|
+
|
40
40
|
private
|
41
|
-
|
41
|
+
|
42
42
|
def find_sprint_and_task
|
43
43
|
@sprint = Sprint.find params[:id]
|
44
44
|
@task = Task.find params[:task_id]
|
45
45
|
end
|
46
|
-
|
46
|
+
|
47
47
|
end
|
@@ -1,17 +1,17 @@
|
|
1
1
|
class SprintsController < ApplicationController
|
2
2
|
attr_reader :sprint, :task
|
3
|
-
|
3
|
+
|
4
4
|
before_filter :authenticate_user!, except: [:dashboard]
|
5
5
|
before_filter :find_sprint, only: [:show, :lock, :add_task, :remove_task]
|
6
6
|
before_filter :find_task, only: [:add_task, :remove_task]
|
7
|
-
|
8
|
-
|
7
|
+
|
8
|
+
|
9
9
|
def current
|
10
10
|
@sprint = Sprint.current || Sprint.create!
|
11
11
|
redirect_to sprint
|
12
12
|
end
|
13
|
-
|
14
|
-
|
13
|
+
|
14
|
+
|
15
15
|
def show
|
16
16
|
authorize! :read, sprint
|
17
17
|
@title = "Sprint #{sprint.end_date.strftime("%-m/%-d")}"
|
@@ -19,12 +19,12 @@ class SprintsController < ApplicationController
|
|
19
19
|
@tasks = @sprint.tasks
|
20
20
|
render template: "sprints/show"
|
21
21
|
end
|
22
|
-
|
23
|
-
|
22
|
+
|
23
|
+
|
24
24
|
def dashboard
|
25
25
|
@title = "Sprint"
|
26
26
|
@sprint = Sprint.find_by_id(params[:id]) || Sprint.current || Sprint.create!
|
27
|
-
|
27
|
+
|
28
28
|
respond_to do |format|
|
29
29
|
format.json { render json: {
|
30
30
|
start: @sprint.start_date,
|
@@ -32,31 +32,31 @@ class SprintsController < ApplicationController
|
|
32
32
|
format.html { render layout: "dashboard" }
|
33
33
|
end
|
34
34
|
end
|
35
|
-
|
36
|
-
|
35
|
+
|
36
|
+
|
37
37
|
def lock
|
38
38
|
authorize! :manage, sprint
|
39
39
|
sprint.lock!
|
40
40
|
head :ok
|
41
41
|
end
|
42
|
-
|
43
|
-
|
42
|
+
|
43
|
+
|
44
44
|
def add_task
|
45
45
|
authorize! :update, sprint
|
46
|
-
|
46
|
+
|
47
47
|
if sprint.completed?
|
48
48
|
render json: {base: ["The Sprint is completed. You cannot add or remove tasks."]}, status: :unprocessable_entity
|
49
49
|
return
|
50
50
|
end
|
51
|
-
|
51
|
+
|
52
52
|
if sprint.locked? && !task.ticket_id.in?(sprint.ticket_ids)
|
53
53
|
render json: {base: ["The Sprint is locked. You can add tasks for tickets that are already in the Sprint, but you can't add new tickets to the Sprint."]}, status: :unprocessable_entity
|
54
54
|
return
|
55
55
|
end
|
56
|
-
|
56
|
+
|
57
57
|
# Putting a task into a Sprint implies that you're able to estimate this ticket
|
58
58
|
task.ticket.able_to_estimate! if task.ticket.respond_to?(:able_to_estimate!)
|
59
|
-
|
59
|
+
|
60
60
|
if task.completed? && task.completed_at < sprint.starts_at
|
61
61
|
render json: {base: ["Task ##{task.shorthand} cannot be added to the Sprint because it was completed before the Sprint began"]}, status: :unprocessable_entity
|
62
62
|
elsif task.effort.nil? or task.effort.zero?
|
@@ -67,33 +67,33 @@ class SprintsController < ApplicationController
|
|
67
67
|
render json: SprintTaskPresenter.new(sprint, task).to_json
|
68
68
|
end
|
69
69
|
end
|
70
|
-
|
70
|
+
|
71
71
|
def remove_task
|
72
72
|
authorize! :update, sprint
|
73
|
-
|
73
|
+
|
74
74
|
if sprint.completed?
|
75
75
|
render json: {base: ["The Sprint is completed. You cannot add or remove tasks."]}, status: :unprocessable_entity
|
76
76
|
return
|
77
77
|
end
|
78
|
-
|
78
|
+
|
79
79
|
if sprint.locked?
|
80
80
|
render json: {base: ["The Sprint is locked; tasks cannot be removed"]}, status: :unprocessable_entity
|
81
81
|
return
|
82
82
|
end
|
83
|
-
|
83
|
+
|
84
84
|
SprintTask.where(sprint_id: sprint.id, task_id: task.id).delete_all
|
85
85
|
head :ok
|
86
86
|
end
|
87
|
-
|
88
|
-
|
87
|
+
|
88
|
+
|
89
89
|
private
|
90
|
-
|
90
|
+
|
91
91
|
def find_sprint
|
92
92
|
@sprint = Sprint.find(params[:id])
|
93
93
|
end
|
94
|
-
|
94
|
+
|
95
95
|
def find_task
|
96
96
|
@task = Task.find(params[:task_id])
|
97
97
|
end
|
98
|
-
|
98
|
+
|
99
99
|
end
|
@@ -1,11 +1,11 @@
|
|
1
1
|
class TasksController < ApplicationController
|
2
2
|
before_filter :find_task
|
3
|
-
|
3
|
+
|
4
4
|
attr_reader :task
|
5
|
-
|
5
|
+
|
6
6
|
def update
|
7
7
|
authorize! :update, task
|
8
|
-
|
8
|
+
|
9
9
|
project = task.project
|
10
10
|
effort = params[:effort]
|
11
11
|
effort = effort.to_d if effort
|
@@ -14,27 +14,27 @@ class TasksController < ApplicationController
|
|
14
14
|
task.update_attributes effort: effort
|
15
15
|
render json: [], status: :ok
|
16
16
|
end
|
17
|
-
|
17
|
+
|
18
18
|
def complete
|
19
19
|
authorize! :update, task
|
20
|
-
|
20
|
+
|
21
21
|
# !todo: authorize completing a task
|
22
22
|
task.complete! unless task.completed?
|
23
23
|
render json: TaskPresenter.new(task)
|
24
24
|
end
|
25
|
-
|
25
|
+
|
26
26
|
def reopen
|
27
27
|
authorize! :update, task
|
28
|
-
|
28
|
+
|
29
29
|
# !todo: authorize completing a task
|
30
30
|
task.reopen! unless task.open?
|
31
31
|
render json: TaskPresenter.new(task)
|
32
32
|
end
|
33
|
-
|
33
|
+
|
34
34
|
private
|
35
|
-
|
35
|
+
|
36
36
|
def find_task
|
37
37
|
@task = Task.find params[:id]
|
38
38
|
end
|
39
|
-
|
39
|
+
|
40
40
|
end
|
@@ -1,35 +1,35 @@
|
|
1
1
|
class TestRunsController < ApplicationController
|
2
2
|
before_filter :find_test_run
|
3
|
-
|
3
|
+
|
4
4
|
def show
|
5
5
|
@title = "Test Results for #{@test_run.sha[0...8]}"
|
6
6
|
render template: "project_notification/test_run"
|
7
7
|
end
|
8
|
-
|
8
|
+
|
9
9
|
def confirm_retry
|
10
10
|
end
|
11
|
-
|
11
|
+
|
12
12
|
def retry
|
13
13
|
@test_run.retry!
|
14
|
-
|
14
|
+
|
15
15
|
build_url = if @project.ci_server.respond_to? :last_build_progress_url
|
16
16
|
@project.ci_server.last_build_progress_url
|
17
17
|
elsif @project.ci_server.respond_to? :last_build_url
|
18
18
|
@project.ci_server.last_build_url
|
19
19
|
end
|
20
|
-
|
20
|
+
|
21
21
|
if build_url
|
22
22
|
redirect_to build_url
|
23
23
|
else
|
24
24
|
redirect_to root_url, notice: "Build for #{@project.name} retried"
|
25
25
|
end
|
26
26
|
end
|
27
|
-
|
27
|
+
|
28
28
|
private
|
29
|
-
|
29
|
+
|
30
30
|
def find_test_run
|
31
31
|
@project = Project.find_by_slug!(params[:slug])
|
32
32
|
@test_run = @project.test_runs.find_by_sha(params[:commit]) || (raise ActiveRecord::RecordNotFound)
|
33
33
|
end
|
34
|
-
|
34
|
+
|
35
35
|
end
|
@@ -1,5 +1,5 @@
|
|
1
1
|
class TesterBarController < ApplicationController
|
2
|
-
|
2
|
+
|
3
3
|
def login_as
|
4
4
|
user = User.find_by_email(params[:email])
|
5
5
|
if user
|
@@ -8,5 +8,5 @@ class TesterBarController < ApplicationController
|
|
8
8
|
end
|
9
9
|
redirect_to request.referrer || root_url
|
10
10
|
end
|
11
|
-
|
11
|
+
|
12
12
|
end
|