mirror of
https://github.com/discourse/discourse.git
synced 2025-01-08 01:03:50 +08:00
180 lines
6.0 KiB
JavaScript
180 lines
6.0 KiB
JavaScript
module("Discourse.ClickTrack", {
|
|
setup: function() {
|
|
|
|
// Prevent any of these tests from navigating away
|
|
this.win = {focus: function() { } };
|
|
this.redirectTo = sinon.stub(Discourse.URL, "redirectTo");
|
|
sinon.stub(Discourse, "ajax");
|
|
this.windowOpen = sinon.stub(window, "open").returns(this.win);
|
|
sinon.stub(this.win, "focus");
|
|
|
|
$('#qunit-scratch').html([
|
|
'<div id="topic" id="1337">',
|
|
' <article data-post-id="42" data-user-id="3141">',
|
|
' <a href="http://www.google.com">google.com</a>',
|
|
' <a class="lightbox back quote-other-topic" href="http://www.google.com">google.com</a>',
|
|
' <a id="with-badge" data-user-id="314" href="http://www.google.com">google.com<span class="badge">1</span></a>',
|
|
' <a id="with-badge-but-not-mine" href="http://www.google.com">google.com<span class="badge">1</span></a>',
|
|
' <div class="onebox-result">',
|
|
' <a id="inside-onebox" href="http://www.google.com">google.com<span class="badge">1</span></a>',
|
|
' <a id="inside-onebox-forced" class="track-link" href="http://www.google.com">google.com<span class="badge">1</span></a>',
|
|
' </div>',
|
|
' <a id="same-site" href="http://discuss.domain.com">forum</a>',
|
|
' <a class="attachment" href="http://discuss.domain.com/uploads/default/1234/1532357280.txt">log.txt</a>',
|
|
' </article>',
|
|
'</div>'].join("\n"));
|
|
},
|
|
|
|
teardown: function() {
|
|
$('#topic').remove();
|
|
$('#qunit-scratch').html('');
|
|
|
|
Discourse.URL.redirectTo.restore();
|
|
Discourse.ajax.restore();
|
|
window.open.restore();
|
|
this.win.focus.restore();
|
|
}
|
|
});
|
|
|
|
var track = Discourse.ClickTrack.trackClick;
|
|
|
|
// test
|
|
var generateClickEventOn = function(selector) {
|
|
return $.Event("click", { currentTarget: $(selector)[0] });
|
|
};
|
|
|
|
test("does not track clicks on lightboxes", function() {
|
|
var clickEvent = generateClickEventOn('.lightbox');
|
|
this.stub(clickEvent, "preventDefault");
|
|
ok(track(clickEvent));
|
|
ok(!clickEvent.preventDefault.calledOnce);
|
|
});
|
|
|
|
test("it calls preventDefault when clicking on an a", function() {
|
|
var clickEvent = generateClickEventOn('a');
|
|
this.stub(clickEvent, "preventDefault");
|
|
track(clickEvent);
|
|
ok(clickEvent.preventDefault.calledOnce);
|
|
ok(Discourse.URL.redirectTo.calledOnce);
|
|
});
|
|
|
|
test("does not track clicks on back buttons", function() {
|
|
ok(track(generateClickEventOn('.back')));
|
|
});
|
|
|
|
test("does not track clicks on quote buttons", function() {
|
|
ok(track(generateClickEventOn('.quote-other-topic')));
|
|
});
|
|
|
|
test("removes the href and put it as a data attribute", function() {
|
|
track(generateClickEventOn('a'));
|
|
|
|
var $link = $('a').first();
|
|
ok($link.hasClass('no-href'));
|
|
equal($link.data('href'), 'http://www.google.com');
|
|
blank($link.attr('href'));
|
|
ok($link.data('auto-route'));
|
|
ok(Discourse.URL.redirectTo.calledOnce);
|
|
});
|
|
|
|
|
|
var badgeClickCount = function(id, expected) {
|
|
track(generateClickEventOn('#' + id));
|
|
var $badge = $('span.badge', $('#' + id).first());
|
|
equal(parseInt($badge.html(), 10), expected);
|
|
};
|
|
|
|
test("does not update badge clicks on my own link", function() {
|
|
this.stub(Discourse.User, 'currentProp').withArgs('id').returns(314);
|
|
badgeClickCount('with-badge', 1);
|
|
});
|
|
|
|
test("does not update badge clicks in my own post", function() {
|
|
this.stub(Discourse.User, 'currentProp').withArgs('id').returns(3141);
|
|
badgeClickCount('with-badge-but-not-mine', 1);
|
|
});
|
|
|
|
test("updates badge counts correctly", function() {
|
|
badgeClickCount('inside-onebox', 1);
|
|
badgeClickCount('inside-onebox-forced', 2);
|
|
badgeClickCount('with-badge', 2);
|
|
});
|
|
|
|
var trackRightClick = function() {
|
|
var clickEvent = generateClickEventOn('a');
|
|
clickEvent.which = 3;
|
|
return track(clickEvent);
|
|
};
|
|
|
|
test("right clicks change the href", function() {
|
|
ok(trackRightClick());
|
|
equal($('a').first().prop('href'), "http://www.google.com/");
|
|
});
|
|
|
|
test("right clicks are tracked", function() {
|
|
Discourse.SiteSettings.track_external_right_clicks = true;
|
|
trackRightClick();
|
|
equal($('a').first().attr('href'), "/clicks/track?url=http%3A%2F%2Fwww.google.com&post_id=42");
|
|
});
|
|
|
|
|
|
var expectToOpenInANewTab = function(clickEvent) {
|
|
ok(!track(clickEvent));
|
|
ok(Discourse.ajax.calledOnce);
|
|
ok(window.open.calledOnce);
|
|
};
|
|
|
|
test("it opens in a new tab when pressing shift", function() {
|
|
var clickEvent = generateClickEventOn('a');
|
|
clickEvent.shiftKey = true;
|
|
expectToOpenInANewTab(clickEvent);
|
|
});
|
|
|
|
test("it opens in a new tab when pressing meta", function() {
|
|
var clickEvent = generateClickEventOn('a');
|
|
clickEvent.metaKey = true;
|
|
expectToOpenInANewTab(clickEvent);
|
|
});
|
|
|
|
test("it opens in a new tab when pressing meta", function() {
|
|
var clickEvent = generateClickEventOn('a');
|
|
clickEvent.ctrlKey = true;
|
|
expectToOpenInANewTab(clickEvent);
|
|
});
|
|
|
|
test("it opens in a new tab when pressing meta", function() {
|
|
var clickEvent = generateClickEventOn('a');
|
|
clickEvent.which = 2;
|
|
expectToOpenInANewTab(clickEvent);
|
|
});
|
|
|
|
test("tracks via AJAX if we're on the same site", function() {
|
|
this.stub(Discourse.URL, "routeTo");
|
|
this.stub(Discourse.URL, "origin").returns("http://discuss.domain.com");
|
|
|
|
ok(!track(generateClickEventOn('#same-site')));
|
|
ok(Discourse.ajax.calledOnce);
|
|
ok(Discourse.URL.routeTo.calledOnce);
|
|
});
|
|
|
|
test("does not track via AJAX for attachments", function() {
|
|
this.stub(Discourse.URL, "routeTo");
|
|
this.stub(Discourse.URL, "origin").returns("http://discuss.domain.com");
|
|
|
|
ok(!track(generateClickEventOn('.attachment')));
|
|
ok(Discourse.URL.redirectTo.calledOnce);
|
|
});
|
|
|
|
test("tracks custom urls when opening in another window", function() {
|
|
var clickEvent = generateClickEventOn('a');
|
|
this.stub(Discourse.User, "currentProp").withArgs('external_links_in_new_tab').returns(true);
|
|
ok(!track(clickEvent));
|
|
ok(this.windowOpen.calledWith('/clicks/track?url=http%3A%2F%2Fwww.google.com&post_id=42', '_blank'));
|
|
});
|
|
|
|
test("tracks custom urls when opening in another window", function() {
|
|
var clickEvent = generateClickEventOn('a');
|
|
ok(!track(clickEvent));
|
|
ok(this.redirectTo.calledWith('/clicks/track?url=http%3A%2F%2Fwww.google.com&post_id=42'));
|
|
});
|