Commit 825eec24 authored by Axel García's avatar Axel García Committed by Axel Garcia

Use track-action on specs

It also updates some related files, like data
attributes on HAML templates and dataset
auto properties (track-event => trackEvent)
parent bf10fa8d
...@@ -2,10 +2,12 @@ import $ from 'jquery'; ...@@ -2,10 +2,12 @@ import $ from 'jquery';
import Tracking from '~/tracking'; import Tracking from '~/tracking';
export default function initTrackInviteMembers(userDropdown) { export default function initTrackInviteMembers(userDropdown) {
const { trackEvent, trackLabel } = userDropdown.querySelector('.js-invite-members-track').dataset; const { trackAction, trackLabel } = userDropdown.querySelector(
'.js-invite-members-track',
).dataset;
$(userDropdown).on('shown.bs.dropdown', () => { $(userDropdown).on('shown.bs.dropdown', () => {
Tracking.event(undefined, trackEvent, { Tracking.event(undefined, trackAction, {
label: trackLabel, label: trackLabel,
}); });
}); });
......
%h4.gl-mt-0.gl-mb-3{ data: { testid: 'invite-member-section', %h4.gl-mt-0.gl-mb-3{ data: { testid: 'invite-member-section',
track_label: 'invite_members_empty_project', track_label: 'invite_members_empty_project',
track_event: 'render' } } track_action: 'render' } }
= s_('InviteMember|Invite your team') = s_('InviteMember|Invite your team')
%p= s_('InviteMember|Add members to this project and start collaborating with your team.') %p= s_('InviteMember|Add members to this project and start collaborating with your team.')
.js-invite-members-trigger{ data: { variant: 'confirm', .js-invite-members-trigger{ data: { variant: 'confirm',
......
.js-blob-result.gl-mt-3.gl-mb-5{ data: { qa_selector: 'result_item_content' } } .js-blob-result.gl-mt-3.gl-mb-5{ data: { qa_selector: 'result_item_content' } }
.file-holder.file-holder-top-border .file-holder.file-holder-top-border
.js-file-title.file-title{ data: { qa_selector: 'file_title_content' } } .js-file-title.file-title{ data: { qa_selector: 'file_title_content' } }
= link_to blob_link, data: {track_event: 'click_text', track_label: 'blob_path', track_property: 'search_result'} do = link_to blob_link, data: {track_action: 'click_text', track_label: 'blob_path', track_property: 'search_result'} do
= sprite_icon('document') = sprite_icon('document')
%strong %strong
= search_blob_title(project, path) = search_blob_title(project, path)
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
%span.gl-display-flex.gl-align-items-center %span.gl-display-flex.gl-align-items-center
%span.badge.badge-pill.gl-badge.sm{ class: "badge-#{issuable_state_to_badge_class(issuable)}" }= issuable_state_text(issuable) %span.badge.badge-pill.gl-badge.sm{ class: "badge-#{issuable_state_to_badge_class(issuable)}" }= issuable_state_text(issuable)
= sprite_icon('eye-slash', css_class: 'gl-text-gray-500 gl-ml-2') if issuable.respond_to?(:confidential?) && issuable.confidential? = sprite_icon('eye-slash', css_class: 'gl-text-gray-500 gl-ml-2') if issuable.respond_to?(:confidential?) && issuable.confidential?
= link_to issuable_path(issuable), data: { track_event: 'click_text', track_label: "#{issuable.class.name.downcase}_title", track_property: 'search_result' }, class: 'gl-w-full' do = link_to issuable_path(issuable), data: { track_action: 'click_text', track_label: "#{issuable.class.name.downcase}_title", track_property: 'search_result' }, class: 'gl-w-full' do
%span.term.str-truncated.gl-font-weight-bold.gl-ml-2= issuable.title %span.term.str-truncated.gl-font-weight-bold.gl-ml-2= issuable.title
.gl-text-gray-500.gl-my-3 .gl-text-gray-500.gl-my-3
= issuable_project_reference(issuable) = issuable_project_reference(issuable)
......
.search-result-row .search-result-row
%h4 %h4
= link_to project_milestone_path(milestone.project, milestone), data: {track_event: 'click_text', track_label: 'milestone_title', track_property: 'search_result'} do = link_to project_milestone_path(milestone.project, milestone), data: {track_action: 'click_text', track_label: 'milestone_title', track_property: 'search_result'} do
%span.term.str-truncated= milestone.title %span.term.str-truncated= milestone.title
- if milestone.description.present? - if milestone.description.present?
......
...@@ -18,7 +18,7 @@ ...@@ -18,7 +18,7 @@
- else - else
%span #{note.noteable_type.titleize} ##{noteable_identifier} %span #{note.noteable_type.titleize} ##{noteable_identifier}
· ·
= link_to note.noteable.title, note_url, data: {track_event: 'click_text', track_label: 'noteable_title', track_property: 'search_result'} = link_to note.noteable.title, note_url, data: {track_action: 'click_text', track_label: 'noteable_title', track_property: 'search_result'}
%span.note-headline-light.note-headline-meta %span.note-headline-light.note-headline-meta
%span.system-note-separator %span.system-note-separator
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
%div{ class: 'search-result-row gl-pb-3! gl-mt-5 gl-mb-0!' } %div{ class: 'search-result-row gl-pb-3! gl-mt-5 gl-mb-0!' }
%span.gl-display-flex.gl-align-items-center %span.gl-display-flex.gl-align-items-center
= link_to wiki_blob_link, data: { track_event: 'click_text', track_label: "wiki_title", track_property: 'search_result' }, class: 'gl-w-full' do = link_to wiki_blob_link, data: { track_action: 'click_text', track_label: "wiki_title", track_property: 'search_result' }, class: 'gl-w-full' do
%span.term.str-truncated.gl-font-weight-bold= ::Gitlab::Git::Wiki::GollumSlug.canonicalize_filename(wiki_blob.path) %span.term.str-truncated.gl-font-weight-bold= ::Gitlab::Git::Wiki::GollumSlug.canonicalize_filename(wiki_blob.path)
.description.term.col-sm-10.gl-px-0 .description.term.col-sm-10.gl-px-0
= simple_search_highlight_and_truncate(wiki_blob.data, @search_term) = simple_search_highlight_and_truncate(wiki_blob.data, @search_term)
...@@ -9,7 +9,7 @@ ...@@ -9,7 +9,7 @@
= link_to s_('UsageQuota|Buy additional minutes'), = link_to s_('UsageQuota|Buy additional minutes'),
link_to_buy_additional_minutes_path(namespace), link_to_buy_additional_minutes_path(namespace),
class: 'gl-button btn btn-confirm float-right', class: 'gl-button btn btn-confirm float-right',
data: { track_event: 'click_buy_ci_minutes', track_label: namespace.actual_plan_name, track_property: 'pipeline_quota_page' } data: { track_action: 'click_buy_ci_minutes', track_label: namespace.actual_plan_name, track_property: 'pipeline_quota_page' }
.row .row
.col-sm-6 .col-sm-6
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
- else - else
%span.badge.badge-success.badge-pill.gl-badge.sm= _("Open") %span.badge.badge-success.badge-pill.gl-badge.sm= _("Open")
= sprite_icon('eye-slash', css_class: 'gl-text-gray-500 gl-ml-2') if epic.confidential? = sprite_icon('eye-slash', css_class: 'gl-text-gray-500 gl-ml-2') if epic.confidential?
= link_to group_epic_path(epic.group, epic), data: { track_event: 'click_text', track_label: 'epic_title', track_property: 'search_result' }, class: 'gl-w-full' do = link_to group_epic_path(epic.group, epic), data: { track_action: 'click_text', track_label: 'epic_title', track_property: 'search_result' }, class: 'gl-w-full' do
%span.term.str-truncated.gl-font-weight-bold.gl-ml-2= epic.title %span.term.str-truncated.gl-font-weight-bold.gl-ml-2= epic.title
.gl-text-gray-500.gl-my-3 .gl-text-gray-500.gl-my-3
= sprintf(s_('%{group_name}&%{epic_iid} · created %{epic_created} by %{author}'), { group_name: epic.group.full_name, epic_iid: epic.iid, epic_created: time_ago_with_tooltip(epic.created_at, placement: 'bottom'), author: link_to_member(@project, epic.author, avatar: false) }).html_safe = sprintf(s_('%{group_name}&%{epic_iid} · created %{epic_created} by %{author}'), { group_name: epic.group.full_name, epic_iid: epic.iid, epic_created: time_ago_with_tooltip(epic.created_at, placement: 'bottom'), author: link_to_member(@project, epic.author, avatar: false) }).html_safe
......
...@@ -157,7 +157,7 @@ RSpec.describe 'Groups > Usage Quotas' do ...@@ -157,7 +157,7 @@ RSpec.describe 'Groups > Usage Quotas' do
link = page.find('a', text: 'Buy additional minutes') link = page.find('a', text: 'Buy additional minutes')
expect(link['data-track-event']).to eq('click_buy_ci_minutes') expect(link['data-track-action']).to eq('click_buy_ci_minutes')
expect(link['data-track-label']).to eq(group.actual_plan_name) expect(link['data-track-label']).to eq(group.actual_plan_name)
expect(link['data-track-property']).to eq('pipeline_quota_page') expect(link['data-track-property']).to eq('pipeline_quota_page')
end end
......
...@@ -224,7 +224,7 @@ RSpec.describe 'Pipeline', :js do ...@@ -224,7 +224,7 @@ RSpec.describe 'Pipeline', :js do
expect(page).to have_content('Method `new_array` has 12 arguments (exceeds 4 allowed). Consider refactoring.') expect(page).to have_content('Method `new_array` has 12 arguments (exceeds 4 allowed). Consider refactoring.')
expect(find_link('foo.rb:10')[:href]).to end_with(project_blob_path(project, File.join(pipeline.commit.id, 'foo.rb')) + '#L10') expect(find_link('foo.rb:10')[:href]).to end_with(project_blob_path(project, File.join(pipeline.commit.id, 'foo.rb')) + '#L10')
expect(page).to have_selector('[data-track-event="click_button"]') expect(page).to have_selector('[data-track-action="click_button"]')
expect(page).to have_selector('[data-track-label="get_codequality_report"]') expect(page).to have_selector('[data-track-label="get_codequality_report"]')
end end
end end
......
...@@ -14,7 +14,7 @@ RSpec.describe 'layouts/application' do ...@@ -14,7 +14,7 @@ RSpec.describe 'layouts/application' do
end end
describe 'layouts/_user_notification_dot' do describe 'layouts/_user_notification_dot' do
let(:track_selector) { '[data-track-event="render"][data-track-label="show_buy_ci_minutes_notification"]' } let(:track_selector) { '[data-track-action="render"][data-track-label="show_buy_ci_minutes_notification"]' }
let(:show_notification_dot) { false } let(:show_notification_dot) { false }
before do before do
......
...@@ -25,7 +25,7 @@ RSpec.describe 'layouts/header/_current_user_dropdown' do ...@@ -25,7 +25,7 @@ RSpec.describe 'layouts/header/_current_user_dropdown' do
context 'when pipeline minutes need bought without notification dot' do context 'when pipeline minutes need bought without notification dot' do
it 'has "Buy Pipeline minutes" link with correct data properties', :aggregate_failures do it 'has "Buy Pipeline minutes" link with correct data properties', :aggregate_failures do
expect(subject).to have_selector('[data-track-event="click_buy_ci_minutes"]') expect(subject).to have_selector('[data-track-action="click_buy_ci_minutes"]')
expect(subject).to have_selector("[data-track-label='#{user.namespace.actual_plan_name}']") expect(subject).to have_selector("[data-track-label='#{user.namespace.actual_plan_name}']")
expect(subject).to have_selector('[data-track-property="user_dropdown"]') expect(subject).to have_selector('[data-track-property="user_dropdown"]')
expect(subject).to have_link('Buy Pipeline minutes') expect(subject).to have_link('Buy Pipeline minutes')
......
...@@ -117,7 +117,7 @@ RSpec.describe 'Issue Sidebar' do ...@@ -117,7 +117,7 @@ RSpec.describe 'Issue Sidebar' do
page.within '.dropdown-menu-user' do page.within '.dropdown-menu-user' do
expect(page).to have_link('Invite members') expect(page).to have_link('Invite members')
expect(page).to have_selector('[data-track-event="click_invite_members"]') expect(page).to have_selector('[data-track-action="click_invite_members"]')
expect(page).to have_selector('[data-track-label="edit_assignee"]') expect(page).to have_selector('[data-track-label="edit_assignee"]')
end end
......
...@@ -26,7 +26,7 @@ RSpec.describe 'Merge request > User edits reviewers sidebar', :js do ...@@ -26,7 +26,7 @@ RSpec.describe 'Merge request > User edits reviewers sidebar', :js do
page.within '.dropdown-menu-user' do page.within '.dropdown-menu-user' do
expect(page).to have_link('Invite Members') expect(page).to have_link('Invite Members')
expect(page).to have_selector('[data-track-event="click_invite_members"]') expect(page).to have_selector('[data-track-action="click_invite_members"]')
expect(page).to have_selector('[data-track-label="edit_reviewer"]') expect(page).to have_selector('[data-track-label="edit_reviewer"]')
end end
......
...@@ -78,7 +78,7 @@ describe('RecoveryCodes', () => { ...@@ -78,7 +78,7 @@ describe('RecoveryCodes', () => {
it('fires Snowplow event', () => { it('fires Snowplow event', () => {
expect(findProceedButton().attributes()).toMatchObject({ expect(findProceedButton().attributes()).toMatchObject({
'data-track-event': 'click_button', 'data-track-action': 'click_button',
'data-track-label': '2fa_recovery_codes_proceed_button', 'data-track-label': '2fa_recovery_codes_proceed_button',
}); });
}); });
......
...@@ -323,7 +323,7 @@ describe('deprecatedJQueryDropdown', () => { ...@@ -323,7 +323,7 @@ describe('deprecatedJQueryDropdown', () => {
const li = dropdown.renderItem(item, null, 3); const li = dropdown.renderItem(item, null, 3);
const link = li.querySelector('a'); const link = li.querySelector('a');
expect(link).toHaveAttr('data-track-event', 'click_text'); expect(link).toHaveAttr('data-track-action', 'click_text');
expect(link).toHaveAttr('data-track-label', 'some_value_for_label'); expect(link).toHaveAttr('data-track-label', 'some_value_for_label');
expect(link).toHaveAttr('data-track-value', '3'); expect(link).toHaveAttr('data-track-value', '3');
expect(link).toHaveAttr('data-track-property', 'suggestion-category'); expect(link).toHaveAttr('data-track-property', 'suggestion-category');
......
...@@ -15,7 +15,7 @@ RSpec.shared_examples 'issuable invite members' do ...@@ -15,7 +15,7 @@ RSpec.shared_examples 'issuable invite members' do
page.within '.dropdown-menu-user' do page.within '.dropdown-menu-user' do
expect(page).to have_link('Invite Members') expect(page).to have_link('Invite Members')
expect(page).to have_selector('[data-track-event="click_invite_members"]') expect(page).to have_selector('[data-track-action="click_invite_members"]')
expect(page).to have_selector('[data-track-label="edit_assignee"]') expect(page).to have_selector('[data-track-label="edit_assignee"]')
end end
......
...@@ -53,7 +53,7 @@ RSpec.describe 'projects/empty' do ...@@ -53,7 +53,7 @@ RSpec.describe 'projects/empty' do
it 'shows invite members info', :aggregate_failures do it 'shows invite members info', :aggregate_failures do
render render
expect(rendered).to have_selector('[data-track-event=render]') expect(rendered).to have_selector('[data-track-action=render]')
expect(rendered).to have_selector('[data-track-label=invite_members_empty_project]') expect(rendered).to have_selector('[data-track-label=invite_members_empty_project]')
expect(rendered).to have_content('Invite your team') expect(rendered).to have_content('Invite your team')
expect(rendered).to have_content('Add members to this project and start collaborating with your team.') expect(rendered).to have_content('Add members to this project and start collaborating with your team.')
......
...@@ -74,7 +74,7 @@ RSpec.describe 'search/_results' do ...@@ -74,7 +74,7 @@ RSpec.describe 'search/_results' do
it 'renders the click text event tracking attributes' do it 'renders the click text event tracking attributes' do
render render
expect(rendered).to have_selector('[data-track-event=click_text]') expect(rendered).to have_selector('[data-track-action=click_text]')
expect(rendered).to have_selector('[data-track-property=search_result]') expect(rendered).to have_selector('[data-track-property=search_result]')
end end
end end
...@@ -83,7 +83,7 @@ RSpec.describe 'search/_results' do ...@@ -83,7 +83,7 @@ RSpec.describe 'search/_results' do
it 'does not render the click text event tracking attributes' do it 'does not render the click text event tracking attributes' do
render render
expect(rendered).not_to have_selector('[data-track-event=click_text]') expect(rendered).not_to have_selector('[data-track-action=click_text]')
expect(rendered).not_to have_selector('[data-track-property=search_result]') expect(rendered).not_to have_selector('[data-track-property=search_result]')
end end
end end
...@@ -105,7 +105,7 @@ RSpec.describe 'search/_results' do ...@@ -105,7 +105,7 @@ RSpec.describe 'search/_results' do
it 'renders the click text event tracking attributes' do it 'renders the click text event tracking attributes' do
render render
expect(rendered).to have_selector('[data-track-event=click_text]') expect(rendered).to have_selector('[data-track-action=click_text]')
expect(rendered).to have_selector('[data-track-property=search_result]') expect(rendered).to have_selector('[data-track-property=search_result]')
end end
end end
...@@ -114,7 +114,7 @@ RSpec.describe 'search/_results' do ...@@ -114,7 +114,7 @@ RSpec.describe 'search/_results' do
it 'does not render the click text event tracking attributes' do it 'does not render the click text event tracking attributes' do
render render
expect(rendered).not_to have_selector('[data-track-event=click_text]') expect(rendered).not_to have_selector('[data-track-action=click_text]')
expect(rendered).not_to have_selector('[data-track-property=search_result]') expect(rendered).not_to have_selector('[data-track-property=search_result]')
end end
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment