| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363 |
- var request = require("request");
- var qs = require("querystring");
- var uuid = require("uuid");
- var should = require("should");
- var sinon = require("sinon");
- var url = require("url");
- var ua = require("../lib/index.js");
- var utils = require("../lib/utils.js")
- var config = require("../lib/config.js")
- describe("ua", function () {
- describe("#timing", function () {
- var _enqueue;
- beforeEach(function () {
- _enqueue = sinon.stub(ua.Visitor.prototype, "_enqueue", function () {
- if (arguments.length === 3 && typeof arguments[2] === 'function') {
- arguments[2]();
- }
- return this;
- });
- });
- afterEach(function () {
- _enqueue.restore()
- });
- it("should accept arguments (category)", function () {
- var category = Math.random().toString();
- var visitor = ua()
- var result = visitor.timing(category);
- visitor._context = result._context;
- result.should.eql(visitor, "should return a visitor that is identical except for the context");
- result.should.be.instanceof(ua.Visitor);
- result._context.should.eql(_enqueue.args[0][1], "the pageview params should be persisted as the context of the visitor clone")
- _enqueue.calledOnce.should.equal(true, "#_enqueue should have been called once");
- _enqueue.args[0][0].should.equal("timing");
- _enqueue.args[0][1].should.have.keys("utc")
- _enqueue.args[0][1].utc.should.equal(category);
- });
- it("should accept arguments (category, fn)", function () {
- var category = Math.random().toString();
- var fn = sinon.spy();
- var visitor = ua()
- var result = visitor.timing(category, fn);
- visitor._context = result._context;
- result.should.eql(visitor, "should return a visitor that is identical except for the context");
- result.should.be.instanceof(ua.Visitor);
- result._context.should.eql(_enqueue.args[0][1], "the pageview params should be persisted as the context of the visitor clone")
- _enqueue.calledOnce.should.equal(true, "#_enqueue should have been called once");
- _enqueue.args[0][0].should.equal("timing");
- _enqueue.args[0][1].should.have.keys("utc")
- _enqueue.args[0][1].utc.should.equal(category);
- fn.calledOnce.should.equal(true, "callback should have been called once")
- });
- it("should accept arguments (category, variable)", function () {
- var category = Math.random().toString();
- var variable = Math.random().toString();
- var visitor = ua()
- var result = visitor.timing(category, variable);
- visitor._context = result._context;
- result.should.eql(visitor, "should return a visitor that is identical except for the context");
- result.should.be.instanceof(ua.Visitor);
- result._context.should.eql(_enqueue.args[0][1], "the pageview params should be persisted as the context of the visitor clone")
- _enqueue.calledOnce.should.equal(true, "#_enqueue should have been called once");
- _enqueue.args[0][0].should.equal("timing");
- _enqueue.args[0][1].should.have.keys("utc", "utv")
- _enqueue.args[0][1].utc.should.equal(category);
- _enqueue.args[0][1].utv.should.equal(variable);
- });
- it("should accept arguments (category, variable, fn)", function () {
- var category = Math.random().toString();
- var variable = Math.random().toString();
- var fn = sinon.spy();
- var visitor = ua()
- var result = visitor.timing(category, variable, fn);
- visitor._context = result._context;
- result.should.eql(visitor, "should return a visitor that is identical except for the context");
- result.should.be.instanceof(ua.Visitor);
- result._context.should.eql(_enqueue.args[0][1], "the pageview params should be persisted as the context of the visitor clone")
- _enqueue.calledOnce.should.equal(true, "#_enqueue should have been called once");
- _enqueue.args[0][0].should.equal("timing");
- _enqueue.args[0][1].should.have.keys("utc", "utv")
- _enqueue.args[0][1].utc.should.equal(category);
- _enqueue.args[0][1].utv.should.equal(variable);
- fn.calledOnce.should.equal(true, "callback should have been called once")
- });
- it("should accept arguments (category, variable, time)", function () {
- var category = Math.random().toString();
- var variable = Math.random().toString();
- var time = Math.random();
- var visitor = ua()
- var result = visitor.timing(category, variable, time);
- visitor._context = result._context;
- result.should.eql(visitor, "should return a visitor that is identical except for the context");
- result.should.be.instanceof(ua.Visitor);
- result._context.should.eql(_enqueue.args[0][1], "the pageview params should be persisted as the context of the visitor clone")
- _enqueue.calledOnce.should.equal(true, "#_enqueue should have been called once");
- _enqueue.args[0][0].should.equal("timing");
- _enqueue.args[0][1].should.have.keys("utc", "utv", "utt")
- _enqueue.args[0][1].utc.should.equal(category);
- _enqueue.args[0][1].utv.should.equal(variable);
- _enqueue.args[0][1].utt.should.equal(time);
- });
- it("should accept arguments (category, variable, time)", function () {
- var category = Math.random().toString();
- var variable = Math.random().toString();
- var time = Math.random();
- var fn = sinon.spy()
- var visitor = ua()
- var result = visitor.timing(category, variable, time, fn);
- visitor._context = result._context;
- result.should.eql(visitor, "should return a visitor that is identical except for the context");
- result.should.be.instanceof(ua.Visitor);
- result._context.should.eql(_enqueue.args[0][1], "the pageview params should be persisted as the context of the visitor clone")
- _enqueue.calledOnce.should.equal(true, "#_enqueue should have been called once");
- _enqueue.args[0][0].should.equal("timing");
- _enqueue.args[0][1].should.have.keys("utc", "utv", "utt")
- _enqueue.args[0][1].utc.should.equal(category);
- _enqueue.args[0][1].utv.should.equal(variable);
- _enqueue.args[0][1].utt.should.equal(time);
- fn.calledOnce.should.equal(true, "callback should have been called once")
- });
- it("should accept arguments (category, variable, time, label)", function () {
- var category = Math.random().toString();
- var variable = Math.random().toString();
- var time = Math.random();
- var label = Math.random().toString();
- var visitor = ua()
- var result = visitor.timing(category, variable, time, label);
- visitor._context = result._context;
- result.should.eql(visitor, "should return a visitor that is identical except for the context");
- result.should.be.instanceof(ua.Visitor);
- result._context.should.eql(_enqueue.args[0][1], "the pageview params should be persisted as the context of the visitor clone")
- _enqueue.calledOnce.should.equal(true, "#_enqueue should have been called once");
- _enqueue.args[0][0].should.equal("timing");
- _enqueue.args[0][1].should.have.keys("utc", "utv", "utt", "utl")
- _enqueue.args[0][1].utc.should.equal(category);
- _enqueue.args[0][1].utv.should.equal(variable);
- _enqueue.args[0][1].utt.should.equal(time);
- _enqueue.args[0][1].utl.should.equal(label);
- });
- it("should accept arguments (category, variable, time, label, fn)", function () {
- var category = Math.random().toString();
- var variable = Math.random().toString();
- var time = Math.random();
- var label = Math.random().toString();
- var fn = sinon.spy()
- var visitor = ua()
- var result = visitor.timing(category, variable, time, label, fn);
- visitor._context = result._context;
- result.should.eql(visitor, "should return a visitor that is identical except for the context");
- result.should.be.instanceof(ua.Visitor);
- result._context.should.eql(_enqueue.args[0][1], "the pageview params should be persisted as the context of the visitor clone")
- _enqueue.calledOnce.should.equal(true, "#_enqueue should have been called once");
- _enqueue.args[0][0].should.equal("timing");
- _enqueue.args[0][1].should.have.keys("utc", "utv", "utt", "utl")
- _enqueue.args[0][1].utc.should.equal(category);
- _enqueue.args[0][1].utv.should.equal(variable);
- _enqueue.args[0][1].utt.should.equal(time);
- _enqueue.args[0][1].utl.should.equal(label);
- fn.calledOnce.should.equal(true, "callback should have been called once")
- });
- it("should accept arguments (category, variable, time, label, params)", function () {
- var category = Math.random().toString();
- var variable = Math.random().toString();
- var time = Math.random();
- var label = Math.random().toString();
- var params = {p: Math.random().toString()}
- var visitor = ua()
- var result = visitor.timing(category, variable, time, label, params);
- visitor._context = result._context;
- result.should.eql(visitor, "should return a visitor that is identical except for the context");
- result.should.be.instanceof(ua.Visitor);
- result._context.should.eql(_enqueue.args[0][1], "the pageview params should be persisted as the context of the visitor clone")
- _enqueue.calledOnce.should.equal(true, "#_enqueue should have been called once");
- _enqueue.args[0][0].should.equal("timing");
- _enqueue.args[0][1].should.have.keys("utc", "utv", "utt", "utl", "p")
- _enqueue.args[0][1].utc.should.equal(category);
- _enqueue.args[0][1].utv.should.equal(variable);
- _enqueue.args[0][1].utt.should.equal(time);
- _enqueue.args[0][1].utl.should.equal(label);
- _enqueue.args[0][1].p.should.equal(params.p);
- });
- it("should accept arguments (category, variable, time, label, params, fn)", function () {
- var category = Math.random().toString();
- var variable = Math.random().toString();
- var time = Math.random();
- var label = Math.random().toString();
- var params = {p: Math.random().toString()}
- var fn = sinon.spy()
- var visitor = ua()
- var result = visitor.timing(category, variable, time, label, params, fn);
- visitor._context = result._context;
- result.should.eql(visitor, "should return a visitor that is identical except for the context");
- result.should.be.instanceof(ua.Visitor);
- result._context.should.eql(_enqueue.args[0][1], "the pageview params should be persisted as the context of the visitor clone")
- _enqueue.calledOnce.should.equal(true, "#_enqueue should have been called once");
- _enqueue.args[0][0].should.equal("timing");
- _enqueue.args[0][1].should.have.keys("utc", "utv", "utt", "utl", "p")
- _enqueue.args[0][1].utc.should.equal(category);
- _enqueue.args[0][1].utv.should.equal(variable);
- _enqueue.args[0][1].utt.should.equal(time);
- _enqueue.args[0][1].utl.should.equal(label);
- _enqueue.args[0][1].p.should.equal(params.p);
- fn.calledOnce.should.equal(true, "callback should have been called once")
- });
- it("should accept arguments (category, variable, time, label, params)", function () {
- var params = {
- utc: Math.random().toString(),
- utv: Math.random().toString(),
- utt: Math.random(),
- utl: Math.random().toString(),
- p: Math.random().toString()
- }
- var visitor = ua()
- var result = visitor.timing(params);
- visitor._context = result._context;
- result.should.eql(visitor, "should return a visitor that is identical except for the context");
- result.should.be.instanceof(ua.Visitor);
- result._context.should.eql(_enqueue.args[0][1], "the pageview params should be persisted as the context of the visitor clone")
- _enqueue.calledOnce.should.equal(true, "#_enqueue should have been called once");
- _enqueue.args[0][0].should.equal("timing");
- _enqueue.args[0][1].should.have.keys("utc", "utv", "utt", "utl", "p")
- _enqueue.args[0][1].utc.should.equal(params.utc);
- _enqueue.args[0][1].utv.should.equal(params.utv);
- _enqueue.args[0][1].utt.should.equal(params.utt);
- _enqueue.args[0][1].utl.should.equal(params.utl);
- _enqueue.args[0][1].p.should.equal(params.p);
- });
- it("should accept arguments (category, variable, time, label, params)", function () {
- var params = {
- utc: Math.random().toString(),
- utv: Math.random().toString(),
- utt: Math.random(),
- utl: Math.random().toString(),
- p: Math.random().toString()
- }
- var fn = sinon.spy()
- var visitor = ua()
- var result = visitor.timing(params, fn);
- visitor._context = result._context;
- result.should.eql(visitor, "should return a visitor that is identical except for the context");
- result.should.be.instanceof(ua.Visitor);
- result._context.should.eql(_enqueue.args[0][1], "the pageview params should be persisted as the context of the visitor clone")
- _enqueue.calledOnce.should.equal(true, "#_enqueue should have been called once");
- _enqueue.args[0][0].should.equal("timing");
- _enqueue.args[0][1].should.have.keys("utc", "utv", "utt", "utl", "p")
- _enqueue.args[0][1].utc.should.equal(params.utc);
- _enqueue.args[0][1].utv.should.equal(params.utv);
- _enqueue.args[0][1].utt.should.equal(params.utt);
- _enqueue.args[0][1].utl.should.equal(params.utl);
- _enqueue.args[0][1].p.should.equal(params.p);
- fn.calledOnce.should.equal(true, "callback should have been called once")
- });
- });
- });
|