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,43 +2,43 @@ class TestingNotesController < ApplicationController
|
|
2
2
|
before_filter :find_ticket
|
3
3
|
before_filter :find_testing_note, :only => [:destroy, :update]
|
4
4
|
before_filter :authenticate_user!, :only => [:create, :update, :destroy]
|
5
|
-
|
6
|
-
|
5
|
+
|
6
|
+
|
7
7
|
def create
|
8
8
|
@testing_note = current_user.testing_notes.build(params[:testing_note].merge(project: @ticket.project))
|
9
|
-
|
9
|
+
|
10
10
|
authorize! :create, @testing_note
|
11
11
|
@testing_note.save
|
12
12
|
render_testing_note
|
13
13
|
end
|
14
|
-
|
15
|
-
|
14
|
+
|
15
|
+
|
16
16
|
def update
|
17
17
|
authorize! :update, @testing_note
|
18
|
-
|
18
|
+
|
19
19
|
@testing_note.update_attributes(params[:testing_note])
|
20
20
|
render_testing_note
|
21
21
|
end
|
22
|
-
|
23
|
-
|
22
|
+
|
23
|
+
|
24
24
|
def destroy
|
25
25
|
authorize! :destroy, @testing_note
|
26
|
-
|
26
|
+
|
27
27
|
@testing_note.destroy
|
28
28
|
head 204
|
29
29
|
end
|
30
|
-
|
31
|
-
|
30
|
+
|
31
|
+
|
32
32
|
private
|
33
|
-
|
33
|
+
|
34
34
|
def find_ticket
|
35
35
|
@ticket = Ticket.find(params[:ticket_id])
|
36
36
|
end
|
37
|
-
|
37
|
+
|
38
38
|
def find_testing_note
|
39
39
|
@testing_note = @ticket.testing_notes.find(params[:id])
|
40
40
|
end
|
41
|
-
|
41
|
+
|
42
42
|
def render_testing_note
|
43
43
|
if @testing_note.errors.any?
|
44
44
|
render json: @testing_note.errors, :status => :unprocessable_entity
|
@@ -46,5 +46,5 @@ private
|
|
46
46
|
render json: TestingNotePresenter.new(@testing_note)
|
47
47
|
end
|
48
48
|
end
|
49
|
-
|
49
|
+
|
50
50
|
end
|
@@ -1,38 +1,38 @@
|
|
1
1
|
class TestingReportController < ApplicationController
|
2
2
|
before_filter :authenticate_user!
|
3
3
|
before_filter :find_project, only: [:show]
|
4
|
-
|
5
|
-
|
4
|
+
|
5
|
+
|
6
6
|
def index
|
7
7
|
@title = "Testing Report"
|
8
|
-
|
8
|
+
|
9
9
|
@projects = followed_projects.select { |project| can?(:read, project.testing_notes.build) }
|
10
10
|
@tickets = Ticket.for_projects @projects
|
11
11
|
end
|
12
|
-
|
13
|
-
|
12
|
+
|
13
|
+
|
14
14
|
def show
|
15
15
|
@title = "Testing Report • #{@project.name}"
|
16
16
|
authorize! :show, @project.testing_notes.build
|
17
|
-
|
17
|
+
|
18
18
|
@projects = [@project]
|
19
19
|
@tickets = @project.tickets
|
20
20
|
end
|
21
|
-
|
22
|
-
|
21
|
+
|
22
|
+
|
23
23
|
private
|
24
|
-
|
25
|
-
|
24
|
+
|
25
|
+
|
26
26
|
def find_project
|
27
27
|
@project = Project.find_by_slug!(params[:slug])
|
28
28
|
end
|
29
|
-
|
30
|
-
|
29
|
+
|
30
|
+
|
31
31
|
def default_render
|
32
32
|
@tickets = TestingReportTicketPresenter.new(@tickets).as_json
|
33
33
|
render json: @tickts if request.xhr?
|
34
34
|
super
|
35
35
|
end
|
36
|
-
|
37
|
-
|
36
|
+
|
37
|
+
|
38
38
|
end
|
@@ -1,12 +1,12 @@
|
|
1
1
|
class TicketsController < ApplicationController
|
2
2
|
before_filter :find_ticket, only: [:show, :update, :close, :reopen]
|
3
|
-
|
3
|
+
|
4
4
|
attr_reader :ticket
|
5
|
-
|
5
|
+
|
6
6
|
def show
|
7
7
|
render json: FullTicketPresenter.new(ticket)
|
8
8
|
end
|
9
|
-
|
9
|
+
|
10
10
|
def update
|
11
11
|
params[:last_release_at] = params.fetch(:lastReleaseAt, params[:last_release_at])
|
12
12
|
attributes = params.pick(:last_release_at, :priority, :summary, :description)
|
@@ -17,11 +17,11 @@ class TicketsController < ApplicationController
|
|
17
17
|
render json: ticket.errors, status: :unprocessable_entity
|
18
18
|
end
|
19
19
|
end
|
20
|
-
|
20
|
+
|
21
21
|
def new
|
22
22
|
@projects = followed_projects.select(&:has_ticket_tracker?)
|
23
23
|
end
|
24
|
-
|
24
|
+
|
25
25
|
def close
|
26
26
|
authorize! :close, ticket
|
27
27
|
ticket.close!
|
@@ -29,7 +29,7 @@ class TicketsController < ApplicationController
|
|
29
29
|
rescue
|
30
30
|
render json: [$!.message], status: :unprocessable_entity
|
31
31
|
end
|
32
|
-
|
32
|
+
|
33
33
|
def reopen
|
34
34
|
authorize! :close, ticket
|
35
35
|
ticket.reopen!
|
@@ -37,12 +37,12 @@ class TicketsController < ApplicationController
|
|
37
37
|
rescue
|
38
38
|
render json: [$!.message], status: :unprocessable_entity
|
39
39
|
end
|
40
|
-
|
40
|
+
|
41
41
|
private
|
42
|
-
|
42
|
+
|
43
43
|
def find_ticket
|
44
44
|
@ticket = Ticket.find(params[:id])
|
45
45
|
@ticket.updated_by = current_user
|
46
46
|
end
|
47
|
-
|
47
|
+
|
48
48
|
end
|
@@ -3,8 +3,8 @@ require 'openssl'
|
|
3
3
|
require 'digest/sha1'
|
4
4
|
|
5
5
|
class UploadsController < ApplicationController
|
6
|
-
|
7
|
-
|
6
|
+
|
7
|
+
|
8
8
|
# Using dropzone to upload straight to S3
|
9
9
|
# https://github.com/enyo/dropzone/issues/33
|
10
10
|
#
|
@@ -24,7 +24,7 @@ class UploadsController < ApplicationController
|
|
24
24
|
unique_file_name = params.values_at(:name, :size, :type).join(".")
|
25
25
|
filename = Digest::SHA1.hexdigest(unique_file_name) + ext
|
26
26
|
object_name = "uploads/#{current_user.id}/#{filename}"
|
27
|
-
|
27
|
+
|
28
28
|
policy_document = MultiJson.dump({
|
29
29
|
"expiration" => 1.day.from_now.utc.iso8601,
|
30
30
|
"conditions" => [
|
@@ -34,15 +34,15 @@ class UploadsController < ApplicationController
|
|
34
34
|
{"success_action_status" => "201"},
|
35
35
|
["content-length-range", 0, 3 * 1048576] # 3 MB
|
36
36
|
]})
|
37
|
-
|
37
|
+
|
38
38
|
policy = Base64.encode64(policy_document).gsub("\n","")
|
39
|
-
|
39
|
+
|
40
40
|
signature = Base64.encode64(
|
41
41
|
OpenSSL::HMAC.digest(
|
42
|
-
OpenSSL::Digest::Digest.new("sha1"),
|
42
|
+
OpenSSL::Digest::Digest.new("sha1"),
|
43
43
|
Houston.config.s3[:secret], policy)
|
44
44
|
).gsub("\n","")
|
45
|
-
|
45
|
+
|
46
46
|
render json: {
|
47
47
|
"AWSAccessKeyId" => Houston.config.s3[:access_key],
|
48
48
|
key: object_name,
|
@@ -51,6 +51,6 @@ class UploadsController < ApplicationController
|
|
51
51
|
success_action_status: 201,
|
52
52
|
acl: "public-read" }
|
53
53
|
end
|
54
|
-
|
55
|
-
|
54
|
+
|
55
|
+
|
56
56
|
end
|
@@ -1,17 +1,17 @@
|
|
1
1
|
class UserCredentialsController < ApplicationController
|
2
|
-
|
2
|
+
|
3
3
|
def upsert
|
4
4
|
credentials = current_user.credentials.where(service: params[:service]).first_or_initialize
|
5
5
|
credentials.login = params[:login]
|
6
6
|
credentials.password = params[:password]
|
7
|
-
|
7
|
+
|
8
8
|
if credentials.save
|
9
9
|
head :ok
|
10
10
|
else
|
11
11
|
render json: credentials.errors, status: :unprocessable_entity
|
12
12
|
end
|
13
13
|
end
|
14
|
-
|
14
|
+
|
15
15
|
def destroy
|
16
16
|
credentials = current_user.credentials.find_by_id(params[:id])
|
17
17
|
if credentials && credentials.delete
|
@@ -20,5 +20,5 @@ class UserCredentialsController < ApplicationController
|
|
20
20
|
redirect_to :back
|
21
21
|
end
|
22
22
|
end
|
23
|
-
|
23
|
+
|
24
24
|
end
|
@@ -1,19 +1,19 @@
|
|
1
1
|
class UserOptionsController < ApplicationController
|
2
2
|
before_filter :authenticate_user!
|
3
|
-
|
4
|
-
|
3
|
+
|
4
|
+
|
5
5
|
def update
|
6
6
|
current_user.view_options = current_user.view_options.merge(params[:options])
|
7
7
|
current_user.save!
|
8
8
|
head :ok
|
9
9
|
end
|
10
|
-
|
11
|
-
|
10
|
+
|
11
|
+
|
12
12
|
def destroy
|
13
13
|
current_user.view_options = current_user.view_options.except(params[:key])
|
14
14
|
current_user.save!
|
15
15
|
head :ok
|
16
16
|
end
|
17
|
-
|
18
|
-
|
17
|
+
|
18
|
+
|
19
19
|
end
|
@@ -1,45 +1,45 @@
|
|
1
1
|
class UsersController < ApplicationController
|
2
2
|
before_filter :extract_administrator, :only => [:update, :create]
|
3
3
|
load_and_authorize_resource
|
4
|
-
|
5
|
-
|
4
|
+
|
5
|
+
|
6
6
|
def index
|
7
7
|
@title = "Team"
|
8
8
|
@users = User.unretired
|
9
|
-
|
9
|
+
|
10
10
|
@ticket_stats_by_user = @users.each_with_object({}) do |user, stats|
|
11
11
|
stats[user] = stats_for_user(user)
|
12
12
|
end
|
13
13
|
end
|
14
|
-
|
15
|
-
|
14
|
+
|
15
|
+
|
16
16
|
def show
|
17
17
|
@user = User.find(params[:id])
|
18
18
|
@title = @user.name
|
19
19
|
@stats = stats_for_user(@user)
|
20
20
|
end
|
21
|
-
|
22
|
-
|
21
|
+
|
22
|
+
|
23
23
|
def new
|
24
24
|
@user = User.new
|
25
25
|
end
|
26
|
-
|
27
|
-
|
26
|
+
|
27
|
+
|
28
28
|
def edit
|
29
29
|
@user = User.find(params[:id])
|
30
30
|
end
|
31
|
-
|
32
|
-
|
31
|
+
|
32
|
+
|
33
33
|
def invite
|
34
34
|
@user = User.find(params[:id])
|
35
35
|
@user.invite!
|
36
36
|
redirect_to request.referrer, :notice => "#{@user.name} has been invited to use this program"
|
37
37
|
end
|
38
|
-
|
39
|
-
|
38
|
+
|
39
|
+
|
40
40
|
def create
|
41
41
|
@user = User.new(user_params)
|
42
|
-
|
42
|
+
|
43
43
|
if params[:send_invitation]
|
44
44
|
User.invite!(params[:user])
|
45
45
|
else
|
@@ -47,23 +47,23 @@ class UsersController < ApplicationController
|
|
47
47
|
@user.skip_password = true
|
48
48
|
@user.save!
|
49
49
|
end
|
50
|
-
|
50
|
+
|
51
51
|
redirect_to @user, notice: 'User was successfully invited.'
|
52
|
-
|
52
|
+
|
53
53
|
rescue ActiveRecord::RecordInvalid
|
54
54
|
flash.now[:error] = @user.errors[:base].join("\n")
|
55
55
|
render action: "new"
|
56
56
|
end
|
57
|
-
|
58
|
-
|
57
|
+
|
58
|
+
|
59
59
|
def update
|
60
60
|
@user = User.find(params[:id])
|
61
61
|
@user.administrator = @administrator
|
62
|
-
|
62
|
+
|
63
63
|
attributes = params[:user]
|
64
64
|
attributes[:alias_emails] = attributes.fetch(:alias_emails, "").split.map(&:strip)
|
65
65
|
attributes[:view_options] = @user.view_options.merge(attributes[:view_options] || {})
|
66
|
-
|
66
|
+
|
67
67
|
if @user.update_attributes(attributes)
|
68
68
|
redirect_to @user, notice: 'User was successfully updated.'
|
69
69
|
else
|
@@ -71,45 +71,45 @@ class UsersController < ApplicationController
|
|
71
71
|
render action: "edit"
|
72
72
|
end
|
73
73
|
end
|
74
|
-
|
75
|
-
|
74
|
+
|
75
|
+
|
76
76
|
def destroy
|
77
77
|
@user = User.find(params[:id])
|
78
78
|
@user.retire!
|
79
|
-
|
79
|
+
|
80
80
|
redirect_to users_url
|
81
81
|
end
|
82
|
-
|
83
|
-
|
82
|
+
|
83
|
+
|
84
84
|
private
|
85
|
-
|
86
|
-
|
85
|
+
|
86
|
+
|
87
87
|
def extract_administrator
|
88
88
|
@administrator = params[:user].delete(:administrator) == "1"
|
89
89
|
@administrator = false unless current_user.administrator?
|
90
90
|
end
|
91
|
-
|
92
|
-
|
91
|
+
|
92
|
+
|
93
93
|
def stats_for_user(user)
|
94
94
|
ticket_resolutions = user.tickets.pluck(:resolution)
|
95
95
|
filed_tickets = ticket_resolutions.count
|
96
96
|
invalid_tickets = ticket_resolutions.count { |resolution| %w{invalid duplicate}.member?(resolution) }
|
97
97
|
fixed_tickets = ticket_resolutions.count { |resolution| resolution == "fixed" }
|
98
98
|
percent = 100.0 / filed_tickets
|
99
|
-
|
99
|
+
|
100
100
|
{
|
101
101
|
tickets: filed_tickets,
|
102
102
|
invalid_tickets: invalid_tickets * percent,
|
103
103
|
fixed_tickets: fixed_tickets * percent
|
104
104
|
}
|
105
105
|
end
|
106
|
-
|
107
|
-
|
106
|
+
|
107
|
+
|
108
108
|
def user_params
|
109
109
|
params.require(:user).permit(:first_name, :last_name, :email,
|
110
110
|
:role, :password, :password_confirmation, :remember_me,
|
111
111
|
:environments_subscribed_to, :view_options, :alias_emails)
|
112
112
|
end
|
113
|
-
|
114
|
-
|
113
|
+
|
114
|
+
|
115
115
|
end
|
@@ -1,18 +1,18 @@
|
|
1
1
|
class WelcomeController < ApplicationController
|
2
2
|
before_filter :authenticate_user!
|
3
3
|
layout "minimal"
|
4
|
-
|
4
|
+
|
5
5
|
def index
|
6
6
|
load_activity
|
7
7
|
end
|
8
|
-
|
8
|
+
|
9
9
|
def activity
|
10
10
|
load_activity
|
11
11
|
render partial: "activity/events"
|
12
12
|
end
|
13
|
-
|
13
|
+
|
14
14
|
private
|
15
|
-
|
15
|
+
|
16
16
|
def load_activity
|
17
17
|
if params[:since]
|
18
18
|
time = Time.parse(params[:since])
|
@@ -21,8 +21,8 @@ private
|
|
21
21
|
time = Time.now
|
22
22
|
@last_date = nil
|
23
23
|
end
|
24
|
-
|
24
|
+
|
25
25
|
@events = ActivityFeed.new(followed_projects, time, count: 150).events
|
26
26
|
end
|
27
|
-
|
27
|
+
|
28
28
|
end
|
data/app/helpers/ansi_helper.rb
CHANGED
@@ -1,5 +1,5 @@
|
|
1
1
|
module AnsiHelper
|
2
|
-
|
2
|
+
|
3
3
|
ANSI_COLOR = {
|
4
4
|
"1" => "ansi-bold",
|
5
5
|
"4" => "ansi-underline",
|
@@ -19,10 +19,10 @@ module AnsiHelper
|
|
19
19
|
"95" => "ansi-bright-magenta",
|
20
20
|
"96" => "ansi-bright-cyan",
|
21
21
|
"97" => "ansi-bright-white" }.freeze
|
22
|
-
|
22
|
+
|
23
23
|
def ansi_to_html(ansi)
|
24
24
|
return "" if ansi.nil?
|
25
|
-
|
25
|
+
|
26
26
|
html = "<div class=\"ansi\">"
|
27
27
|
string = StringScanner.new(ansi.gsub("<", "<"))
|
28
28
|
spans = 0
|
@@ -42,5 +42,5 @@ module AnsiHelper
|
|
42
42
|
html << "</div>"
|
43
43
|
html.html_safe
|
44
44
|
end
|
45
|
-
|
45
|
+
|
46
46
|
end
|
@@ -1,35 +1,35 @@
|
|
1
1
|
module ApplicationHelper
|
2
|
-
|
2
|
+
|
3
3
|
def title
|
4
4
|
@title || Houston.config.title
|
5
5
|
end
|
6
|
-
|
6
|
+
|
7
7
|
def revision
|
8
8
|
controller.revision
|
9
9
|
end
|
10
|
-
|
10
|
+
|
11
11
|
def html_safe(html)
|
12
12
|
html.html_safe
|
13
13
|
end
|
14
|
-
|
14
|
+
|
15
15
|
def header
|
16
16
|
yield PageHeaderBuilder.new(self)
|
17
17
|
"<hr class=\"clear\" />".html_safe
|
18
18
|
end
|
19
|
-
|
19
|
+
|
20
20
|
def custom_link_unless_current(link_text, url)
|
21
21
|
"<li>#{link_to(link_text, url)}</li>".html_safe unless current_page?(url)
|
22
22
|
end
|
23
|
-
|
24
|
-
|
25
|
-
|
23
|
+
|
24
|
+
|
25
|
+
|
26
26
|
def in_columns(collection, options={}, &block)
|
27
27
|
max_size = options.fetch(:max_size, 10)
|
28
28
|
column_count = (collection.length.to_f / max_size).ceil
|
29
29
|
column_count = 1 if column_count < 1
|
30
30
|
in_columns_of(collection, column_count, &block)
|
31
31
|
end
|
32
|
-
|
32
|
+
|
33
33
|
def in_groups_of(collection, column_count, css_class="column")
|
34
34
|
html = collection.in_groups_of(column_count).each_with_object("") do |items_in_column, html|
|
35
35
|
html << "<div class=\"#{css_class}\">"
|
@@ -40,11 +40,11 @@ module ApplicationHelper
|
|
40
40
|
end
|
41
41
|
html.html_safe
|
42
42
|
end
|
43
|
-
|
43
|
+
|
44
44
|
alias :in_columns_of :in_groups_of
|
45
|
-
|
46
|
-
|
47
|
-
|
45
|
+
|
46
|
+
|
47
|
+
|
48
48
|
def format_time(time)
|
49
49
|
if time.nil?
|
50
50
|
date, time = ["", "Never"]
|
@@ -55,43 +55,43 @@ module ApplicationHelper
|
|
55
55
|
else
|
56
56
|
date, time = [time.strftime("%b %e"), time.strftime("%l:%M %p")]
|
57
57
|
end
|
58
|
-
|
58
|
+
|
59
59
|
<<-HTML.html_safe
|
60
60
|
<span class="time-date">#{date}</span>
|
61
61
|
<span class="time-time">#{time.gsub(" AM", "a").gsub(" PM", "p")}</span>
|
62
62
|
HTML
|
63
63
|
end
|
64
|
-
|
64
|
+
|
65
65
|
def format_date_with_year(date)
|
66
66
|
return "" if date.nil?
|
67
67
|
"#{date.strftime("%b %d")}<span class=\"year\">#{date.strftime("%Y")}</span>".html_safe
|
68
68
|
end
|
69
|
-
|
70
|
-
|
71
|
-
|
69
|
+
|
70
|
+
|
71
|
+
|
72
72
|
def follows?(project)
|
73
73
|
followed_projects.member?(project)
|
74
74
|
end
|
75
|
-
|
76
|
-
|
77
|
-
|
75
|
+
|
76
|
+
|
77
|
+
|
78
78
|
end
|
79
79
|
|
80
80
|
|
81
81
|
class PageHeaderBuilder
|
82
|
-
|
82
|
+
|
83
83
|
def initialize(context)
|
84
84
|
@context = context
|
85
85
|
end
|
86
|
-
|
86
|
+
|
87
87
|
delegate :breadcrumbs, :capture, :to => :@context
|
88
|
-
|
88
|
+
|
89
89
|
def actions(&block)
|
90
90
|
html_safe "<div class=\"page-actions\">#{capture(&block)}</div>"
|
91
91
|
end
|
92
|
-
|
92
|
+
|
93
93
|
def html_safe(html)
|
94
94
|
html.html_safe
|
95
95
|
end
|
96
|
-
|
96
|
+
|
97
97
|
end
|
@@ -1,24 +1,24 @@
|
|
1
1
|
module AvatarHelper
|
2
|
-
|
3
|
-
|
4
|
-
|
2
|
+
|
3
|
+
|
4
|
+
|
5
5
|
def avatar_for(user, options={})
|
6
6
|
return "" unless user
|
7
|
-
|
7
|
+
|
8
8
|
size = options.fetch(:size, 24)
|
9
9
|
"<img class=\"avatar user-#{user.id}\" src=\"#{gravatar_url(user.email, size: size * 2)}\" width=\"#{size}\" height=\"#{size}\" alt=\"#{user.name}\" />".html_safe
|
10
10
|
end
|
11
|
-
|
12
|
-
|
11
|
+
|
12
|
+
|
13
13
|
def gravatar_image(email, options={})
|
14
14
|
return "" if email.blank?
|
15
|
-
|
15
|
+
|
16
16
|
size = options.fetch(:size, 24)
|
17
17
|
alt = options[:alt]
|
18
18
|
"<img class=\"avatar\" src=\"#{gravatar_url(email, size: size * 2)}\" width=\"#{size}\" height=\"#{size}\" alt=\"#{alt}\" />".html_safe
|
19
19
|
end
|
20
|
-
|
21
|
-
|
20
|
+
|
21
|
+
|
22
22
|
# http://en.gravatar.com/site/implement/ruby
|
23
23
|
# http://en.gravatar.com/site/implement/url
|
24
24
|
def gravatar_url(email, options={})
|
@@ -26,7 +26,7 @@ module AvatarHelper
|
|
26
26
|
url << "&s=#{options[:size]}" if options.key?(:size)
|
27
27
|
url
|
28
28
|
end
|
29
|
-
|
30
|
-
|
31
|
-
|
29
|
+
|
30
|
+
|
31
|
+
|
32
32
|
end
|