jasmine.TrivialReporter = function() {
};

jasmine.TrivialReporter.prototype.createDom = function(type, attrs, childrenVarArgs) {
  var el = document.createElement(type);

  for (var i = 2; i < arguments.length; i++) {
    var child = arguments[i];

    if (typeof child === 'string') {
      el.appendChild(document.createTextNode(child));
    } else {
      el.appendChild(child);
    }
  }

  for (var attr in attrs) {
    if (attr == 'className') {
      el.setAttribute('class', attrs[attr]);
    } else {
      if (attr.indexOf('x-') == 0) {
        el.setAttribute(attr, attrs[attr]);
      } else {
        el[attr] = attrs[attr];
      }
    }
  }

  return el;
};

jasmine.TrivialReporter.prototype.reportRunnerResults = function(runner) {
  console.log(runner);
};

jasmine.TrivialReporter.prototype.reportSuiteResults = function(suite) {
  console.log(suite);
};

jasmine.TrivialReporter.prototype.reportSpecResults = function(spec) {
  var specDiv = this.createDom('div', {
    className: spec.getResults().passed() ? 'spec passed' : 'spec failed'
  }, spec.getFullName());

  var resultItems = spec.getResults().getItems();
  for (var i = 0; i < resultItems.length; i++) {
    var result = resultItems[i];
    if (!result.passed) {
      var resultMessageDiv = this.createDom('div', {className: 'resultMessage'});
      resultMessageDiv.innerHTML = result.message; // todo: lame; mend
      specDiv.appendChild(resultMessageDiv);
      specDiv.appendChild(this.createDom('div', {className: 'stackTrace'}, result.trace.stack));
    }
  }

  document.body.appendChild(specDiv);
};

jasmine.TrivialReporter.prototype.log = function() {
  console.log.apply(console, arguments);
};