Update Semantic
Fixes #40,#24
This commit is contained in:
parent
1715f27f44
commit
2027b94179
621 changed files with 172488 additions and 15939 deletions
24
web/semantic/test/fixtures/accordion.html
vendored
Normal file
24
web/semantic/test/fixtures/accordion.html
vendored
Normal file
|
@ -0,0 +1,24 @@
|
|||
<div class="ui accordion">
|
||||
<div class="active title">
|
||||
<i class="dropdown icon"></i>
|
||||
What is a dog?
|
||||
</div>
|
||||
<div class="active content">
|
||||
<p>A dog is a type of domesticated animal. Known for its loyalty and faithfulness, it can be found as a welcome guest in many households across the world.</p>
|
||||
</div>
|
||||
<div class="title">
|
||||
<i class="dropdown icon"></i>
|
||||
What kinds of dogs are there?
|
||||
</div>
|
||||
<div class="content">
|
||||
<p>There are many breeds of dogs. Each breed varies in size and temperament. Owners often select a breed of dog that they find to be compatible with their own lifestyle and desires from a companion.</p>
|
||||
</div>
|
||||
<div class="title">
|
||||
<i class="dropdown icon"></i>
|
||||
How do you acquire a dog?
|
||||
</div>
|
||||
<div class="content">
|
||||
<p>Three common ways for a prospective owner to acquire a dog is from pet shops, private owners, or shelters.</p>
|
||||
<p>A pet shop may be the most convenient way to buy a dog. Buying a dog from a private owner allows you to assess the pedigree and upbringing of your dog before choosing to take it home. Lastly, finding your dog from a shelter, helps give a good home to a dog who may not find one so readily.</p>
|
||||
</div>
|
||||
</div>
|
46
web/semantic/test/fixtures/checkbox.html
vendored
Normal file
46
web/semantic/test/fixtures/checkbox.html
vendored
Normal file
|
@ -0,0 +1,46 @@
|
|||
<div class="ui form">
|
||||
<div class="grouped inline fields">
|
||||
<div class="field">
|
||||
<div class="ui radio checkbox">
|
||||
<input type="radio" name="fruit" checked="checked" />
|
||||
<label>Apples</label>
|
||||
</div>
|
||||
</div>
|
||||
<div class="field">
|
||||
<div class="ui radio checkbox">
|
||||
<input type="radio" name="fruit" />
|
||||
<label>Oranges</label>
|
||||
</div>
|
||||
</div>
|
||||
<div class="field">
|
||||
<div class="ui radio checkbox">
|
||||
<input type="radio" name="fruit" />
|
||||
<label>Pears</label>
|
||||
</div>
|
||||
</div>
|
||||
<div class="field">
|
||||
<div class="ui radio checkbox">
|
||||
<input type="radio" name="fruit" />
|
||||
<label>Grapefruit</label>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="field">
|
||||
<div class="ui checkbox">
|
||||
<input type="checkbox">
|
||||
<label>Poodle</label>
|
||||
</div>
|
||||
</div>
|
||||
<div class="field">
|
||||
<div class="ui toggle checkbox">
|
||||
<input type="checkbox" name="pet" />
|
||||
<label>Allow other people to pet my dog</label>
|
||||
</div>
|
||||
</div>
|
||||
<div class="field">
|
||||
<div class="ui slider checkbox">
|
||||
<input type="checkbox" name="pet" />
|
||||
<label>Allow other people to pet my dog</label>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
9
web/semantic/test/fixtures/dropdown.html
vendored
Normal file
9
web/semantic/test/fixtures/dropdown.html
vendored
Normal file
|
@ -0,0 +1,9 @@
|
|||
<div class="ui selection dropdown">
|
||||
<input type="hidden" name="gender">
|
||||
<i class="dropdown icon"></i>
|
||||
<div class="default text">Gender</div>
|
||||
<div class="menu">
|
||||
<div class="item" data-value="male">Male</div>
|
||||
<div class="item" data-value="female">Female</div>
|
||||
</div>
|
||||
</div>
|
25
web/semantic/test/fixtures/modal.html
vendored
Normal file
25
web/semantic/test/fixtures/modal.html
vendored
Normal file
|
@ -0,0 +1,25 @@
|
|||
<div class="ui test modal">
|
||||
<i class="close icon"></i>
|
||||
<div class="header">
|
||||
Profile Picture
|
||||
</div>
|
||||
<div class="content">
|
||||
<div class="left">
|
||||
<img class="ui fluid image">
|
||||
</div>
|
||||
<div class="right">
|
||||
<div class="ui header">Are you sure you want to upload that?</div>
|
||||
<p>I mean it's not really the best profile photo.</p>
|
||||
<p>It's resampled to like two times the size it's suppose to be. Our image detection software also says it might even be inappropriate.</p>
|
||||
</div>
|
||||
</div>
|
||||
<div class="actions">
|
||||
<div class="ui black button">
|
||||
Cancel
|
||||
</div>
|
||||
<div class="ui green right labeled icon button">
|
||||
Add Photo
|
||||
<i class="checkmark icon"></i>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
8
web/semantic/test/fixtures/popup.html
vendored
Normal file
8
web/semantic/test/fixtures/popup.html
vendored
Normal file
|
@ -0,0 +1,8 @@
|
|||
<i class="circular heart icon link" data-content="Top Left" data-position="top left"></i>
|
||||
<i class="circular heart icon link" data-content="Top Center" data-position="top center"></i>
|
||||
<i class="circular heart icon link" data-content="Top Right" data-position="top right"></i>
|
||||
<i class="circular heart icon link" data-content="Left Center" data-position="left center"></i>
|
||||
<i class="circular heart icon link" data-content="Right Center" data-position="right center"></i>
|
||||
<i class="circular heart icon link" data-content="Bottom Left" data-position="bottom left"></i>
|
||||
<i class="circular heart icon link" data-content="Bottom Center" data-position="bottom center"></i>
|
||||
<i class="circular heart icon link" data-content="Bottom Right" data-position="bottom right"></i>
|
7
web/semantic/test/fixtures/rating.html
vendored
Normal file
7
web/semantic/test/fixtures/rating.html
vendored
Normal file
|
@ -0,0 +1,7 @@
|
|||
<div class="ui star rating">
|
||||
<i class="icon"></i>
|
||||
<i class="icon"></i>
|
||||
<i class="icon"></i>
|
||||
<i class="icon"></i>
|
||||
<i class="icon"></i>
|
||||
</div>
|
7
web/semantic/test/fixtures/shape.html
vendored
Normal file
7
web/semantic/test/fixtures/shape.html
vendored
Normal file
|
@ -0,0 +1,7 @@
|
|||
<div class="ui shape">
|
||||
<div class="sides">
|
||||
<div class="active side">This side is visible.</div>
|
||||
<div class="side">This side is not visible.</div>
|
||||
<div class="side">This side is not visible.</div>
|
||||
</div>
|
||||
</div>
|
25
web/semantic/test/fixtures/sidebar.html
vendored
Normal file
25
web/semantic/test/fixtures/sidebar.html
vendored
Normal file
|
@ -0,0 +1,25 @@
|
|||
<div class="ui red vertical demo sidebar menu">
|
||||
<a class="item">
|
||||
<i class="home icon"></i>
|
||||
Home
|
||||
</a>
|
||||
<a class="active item">
|
||||
<i class="heart icon"></i>
|
||||
Current Section
|
||||
</a>
|
||||
<a class="item">
|
||||
<i class="facebook icon"></i>
|
||||
Like us on Facebook
|
||||
</a>
|
||||
<div class="item">
|
||||
<b>More</b>
|
||||
<div class="menu">
|
||||
<a class="item">About</a>
|
||||
<a class="item">Contact Us</a>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="ui disabled teal toggle button">
|
||||
<i class="left arrow icon"></i>
|
||||
Trigger Sidebar
|
||||
</div>
|
8
web/semantic/test/fixtures/tab.html
vendored
Normal file
8
web/semantic/test/fixtures/tab.html
vendored
Normal file
|
@ -0,0 +1,8 @@
|
|||
<div class="ui menu">
|
||||
<a class="active item" data-tab="first">First</a>
|
||||
<a class="item" data-tab="second">Second</a>
|
||||
<a class="item" data-tab="third">Third</a>
|
||||
</div>
|
||||
<div class="ui active tab segment" data-tab="first">First</div>
|
||||
<div class="ui tab segment" data-tab="second">Second</div>
|
||||
<div class="ui tab segment" data-tab="third">Third</div>
|
1
web/semantic/test/fixtures/transition.html
vendored
Normal file
1
web/semantic/test/fixtures/transition.html
vendored
Normal file
|
@ -0,0 +1 @@
|
|||
<div class="ui image"></div>
|
5
web/semantic/test/fixtures/video.html
vendored
Normal file
5
web/semantic/test/fixtures/video.html
vendored
Normal file
|
@ -0,0 +1,5 @@
|
|||
<div class="ui video">
|
||||
<div class="play"></div>
|
||||
<div class="placeholder"></div>
|
||||
<div class="embed"></div>
|
||||
</div>
|
17
web/semantic/test/helpers/jasmine-clog.js
Normal file
17
web/semantic/test/helpers/jasmine-clog.js
Normal file
|
@ -0,0 +1,17 @@
|
|||
// Allow for console.log to not break IE
|
||||
if (typeof window.console == "undefined" || typeof window.console.log == "undefined") {
|
||||
window.console = {
|
||||
log : function() {},
|
||||
info : function(){},
|
||||
warn : function(){}
|
||||
};
|
||||
}
|
||||
if(typeof window.console.group == 'undefined' || typeof window.console.groupEnd == 'undefined' || typeof window.console.groupCollapsed == 'undefined') {
|
||||
window.console.group = function(){};
|
||||
window.console.groupEnd = function(){};
|
||||
window.console.groupCollapsed = function(){};
|
||||
}
|
||||
if(typeof window.console.markTimeline == 'undefined') {
|
||||
window.console.markTimeline = function(){};
|
||||
}
|
||||
window.console.clear = function(){};
|
705
web/semantic/test/helpers/jasmine-jquery.js
Normal file
705
web/semantic/test/helpers/jasmine-jquery.js
Normal file
|
@ -0,0 +1,705 @@
|
|||
/*!
|
||||
Jasmine-jQuery: a set of jQuery helpers for Jasmine tests.
|
||||
|
||||
Version 1.5.91
|
||||
|
||||
https://github.com/velesin/jasmine-jquery
|
||||
|
||||
Copyright (c) 2010-2013 Wojciech Zawistowski, Travis Jeffery
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining
|
||||
a copy of this software and associated documentation files (the
|
||||
"Software"), to deal in the Software without restriction, including
|
||||
without limitation the rights to use, copy, modify, merge, publish,
|
||||
distribute, sublicense, and/or sell copies of the Software, and to
|
||||
permit persons to whom the Software is furnished to do so, subject to
|
||||
the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be
|
||||
included in all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
|
||||
+function (jasmine, $) { "use strict";
|
||||
|
||||
jasmine.spiedEventsKey = function (selector, eventName) {
|
||||
return [$(selector).selector, eventName].toString()
|
||||
}
|
||||
|
||||
jasmine.getFixtures = function () {
|
||||
return jasmine.currentFixtures_ = jasmine.currentFixtures_ || new jasmine.Fixtures()
|
||||
}
|
||||
|
||||
jasmine.getStyleFixtures = function () {
|
||||
return jasmine.currentStyleFixtures_ = jasmine.currentStyleFixtures_ || new jasmine.StyleFixtures()
|
||||
}
|
||||
|
||||
jasmine.Fixtures = function () {
|
||||
this.containerId = 'jasmine-fixtures'
|
||||
this.fixturesCache_ = {}
|
||||
this.fixturesPath = 'spec/javascripts/fixtures'
|
||||
}
|
||||
|
||||
jasmine.Fixtures.prototype.set = function (html) {
|
||||
this.cleanUp()
|
||||
return this.createContainer_(html)
|
||||
}
|
||||
|
||||
jasmine.Fixtures.prototype.appendSet= function (html) {
|
||||
this.addToContainer_(html)
|
||||
}
|
||||
|
||||
jasmine.Fixtures.prototype.preload = function () {
|
||||
this.read.apply(this, arguments)
|
||||
}
|
||||
|
||||
jasmine.Fixtures.prototype.load = function () {
|
||||
this.cleanUp()
|
||||
this.createContainer_(this.read.apply(this, arguments))
|
||||
}
|
||||
|
||||
jasmine.Fixtures.prototype.appendLoad = function () {
|
||||
this.addToContainer_(this.read.apply(this, arguments))
|
||||
}
|
||||
|
||||
jasmine.Fixtures.prototype.read = function () {
|
||||
var htmlChunks = []
|
||||
, fixtureUrls = arguments
|
||||
|
||||
for(var urlCount = fixtureUrls.length, urlIndex = 0; urlIndex < urlCount; urlIndex++) {
|
||||
htmlChunks.push(this.getFixtureHtml_(fixtureUrls[urlIndex]))
|
||||
}
|
||||
|
||||
return htmlChunks.join('')
|
||||
}
|
||||
|
||||
jasmine.Fixtures.prototype.clearCache = function () {
|
||||
this.fixturesCache_ = {}
|
||||
}
|
||||
|
||||
jasmine.Fixtures.prototype.cleanUp = function () {
|
||||
$('#' + this.containerId).remove()
|
||||
}
|
||||
|
||||
jasmine.Fixtures.prototype.sandbox = function (attributes) {
|
||||
var attributesToSet = attributes || {}
|
||||
return $('<div id="sandbox" />').attr(attributesToSet)
|
||||
}
|
||||
|
||||
jasmine.Fixtures.prototype.createContainer_ = function (html) {
|
||||
var container = $('<div>')
|
||||
.attr('id', this.containerId)
|
||||
.html(html)
|
||||
|
||||
$(document.body).append(container)
|
||||
return container
|
||||
}
|
||||
|
||||
jasmine.Fixtures.prototype.addToContainer_ = function (html){
|
||||
var container = $(document.body).find('#'+this.containerId).append(html)
|
||||
if(!container.length){
|
||||
this.createContainer_(html)
|
||||
}
|
||||
}
|
||||
|
||||
jasmine.Fixtures.prototype.getFixtureHtml_ = function (url) {
|
||||
if (typeof this.fixturesCache_[url] === 'undefined') {
|
||||
this.loadFixtureIntoCache_(url)
|
||||
}
|
||||
return this.fixturesCache_[url]
|
||||
}
|
||||
|
||||
jasmine.Fixtures.prototype.loadFixtureIntoCache_ = function (relativeUrl) {
|
||||
var self = this
|
||||
, url = this.makeFixtureUrl_(relativeUrl)
|
||||
, request = $.ajax({
|
||||
async: false, // must be synchronous to guarantee that no tests are run before fixture is loaded
|
||||
cache: false,
|
||||
url: url,
|
||||
success: function (data, status, $xhr) {
|
||||
self.fixturesCache_[relativeUrl] = $xhr.responseText
|
||||
},
|
||||
error: function (jqXHR, status, errorThrown) {
|
||||
throw new Error('Fixture could not be loaded: ' + url + ' (status: ' + status + ', message: ' + errorThrown.message + ')')
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
jasmine.Fixtures.prototype.makeFixtureUrl_ = function (relativeUrl){
|
||||
return this.fixturesPath.match('/$') ? this.fixturesPath + relativeUrl : this.fixturesPath + '/' + relativeUrl
|
||||
}
|
||||
|
||||
jasmine.Fixtures.prototype.proxyCallTo_ = function (methodName, passedArguments) {
|
||||
return this[methodName].apply(this, passedArguments)
|
||||
}
|
||||
|
||||
|
||||
jasmine.StyleFixtures = function () {
|
||||
this.fixturesCache_ = {}
|
||||
this.fixturesNodes_ = []
|
||||
this.fixturesPath = 'spec/javascripts/fixtures'
|
||||
}
|
||||
|
||||
jasmine.StyleFixtures.prototype.set = function (css) {
|
||||
this.cleanUp()
|
||||
this.createStyle_(css)
|
||||
}
|
||||
|
||||
jasmine.StyleFixtures.prototype.appendSet = function (css) {
|
||||
this.createStyle_(css)
|
||||
}
|
||||
|
||||
jasmine.StyleFixtures.prototype.preload = function () {
|
||||
this.read_.apply(this, arguments)
|
||||
}
|
||||
|
||||
jasmine.StyleFixtures.prototype.load = function () {
|
||||
this.cleanUp()
|
||||
this.createStyle_(this.read_.apply(this, arguments))
|
||||
}
|
||||
|
||||
jasmine.StyleFixtures.prototype.appendLoad = function () {
|
||||
this.createStyle_(this.read_.apply(this, arguments))
|
||||
}
|
||||
|
||||
jasmine.StyleFixtures.prototype.cleanUp = function () {
|
||||
while(this.fixturesNodes_.length) {
|
||||
this.fixturesNodes_.pop().remove()
|
||||
}
|
||||
}
|
||||
|
||||
jasmine.StyleFixtures.prototype.createStyle_ = function (html) {
|
||||
var styleText = $('<div></div>').html(html).text()
|
||||
, style = $('<style>' + styleText + '</style>')
|
||||
|
||||
this.fixturesNodes_.push(style)
|
||||
$('head').append(style)
|
||||
}
|
||||
|
||||
jasmine.StyleFixtures.prototype.clearCache = jasmine.Fixtures.prototype.clearCache
|
||||
jasmine.StyleFixtures.prototype.read_ = jasmine.Fixtures.prototype.read
|
||||
jasmine.StyleFixtures.prototype.getFixtureHtml_ = jasmine.Fixtures.prototype.getFixtureHtml_
|
||||
jasmine.StyleFixtures.prototype.loadFixtureIntoCache_ = jasmine.Fixtures.prototype.loadFixtureIntoCache_
|
||||
jasmine.StyleFixtures.prototype.makeFixtureUrl_ = jasmine.Fixtures.prototype.makeFixtureUrl_
|
||||
jasmine.StyleFixtures.prototype.proxyCallTo_ = jasmine.Fixtures.prototype.proxyCallTo_
|
||||
|
||||
jasmine.getJSONFixtures = function () {
|
||||
return jasmine.currentJSONFixtures_ = jasmine.currentJSONFixtures_ || new jasmine.JSONFixtures()
|
||||
}
|
||||
|
||||
jasmine.JSONFixtures = function () {
|
||||
this.fixturesCache_ = {}
|
||||
this.fixturesPath = 'spec/javascripts/fixtures/json'
|
||||
}
|
||||
|
||||
jasmine.JSONFixtures.prototype.load = function () {
|
||||
this.read.apply(this, arguments)
|
||||
return this.fixturesCache_
|
||||
}
|
||||
|
||||
jasmine.JSONFixtures.prototype.read = function () {
|
||||
var fixtureUrls = arguments
|
||||
|
||||
for(var urlCount = fixtureUrls.length, urlIndex = 0; urlIndex < urlCount; urlIndex++) {
|
||||
this.getFixtureData_(fixtureUrls[urlIndex])
|
||||
}
|
||||
|
||||
return this.fixturesCache_
|
||||
}
|
||||
|
||||
jasmine.JSONFixtures.prototype.clearCache = function () {
|
||||
this.fixturesCache_ = {}
|
||||
}
|
||||
|
||||
jasmine.JSONFixtures.prototype.getFixtureData_ = function (url) {
|
||||
if (!this.fixturesCache_[url]) this.loadFixtureIntoCache_(url)
|
||||
return this.fixturesCache_[url]
|
||||
}
|
||||
|
||||
jasmine.JSONFixtures.prototype.loadFixtureIntoCache_ = function (relativeUrl) {
|
||||
var self = this
|
||||
, url = this.fixturesPath.match('/$') ? this.fixturesPath + relativeUrl : this.fixturesPath + '/' + relativeUrl
|
||||
|
||||
$.ajax({
|
||||
async: false, // must be synchronous to guarantee that no tests are run before fixture is loaded
|
||||
cache: false,
|
||||
dataType: 'json',
|
||||
url: url,
|
||||
success: function (data) {
|
||||
self.fixturesCache_[relativeUrl] = data
|
||||
},
|
||||
error: function (jqXHR, status, errorThrown) {
|
||||
throw new Error('JSONFixture could not be loaded: ' + url + ' (status: ' + status + ', message: ' + errorThrown.message + ')')
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
jasmine.JSONFixtures.prototype.proxyCallTo_ = function (methodName, passedArguments) {
|
||||
return this[methodName].apply(this, passedArguments)
|
||||
}
|
||||
|
||||
jasmine.JQuery = function () {}
|
||||
|
||||
jasmine.JQuery.browserTagCaseIndependentHtml = function (html) {
|
||||
return $('<div/>').append(html).html()
|
||||
}
|
||||
|
||||
jasmine.JQuery.elementToString = function (element) {
|
||||
var domEl = $(element).get(0)
|
||||
|
||||
if (domEl === undefined || domEl.cloneNode)
|
||||
return $('<div />').append($(element).clone()).html()
|
||||
else
|
||||
return element.toString()
|
||||
}
|
||||
|
||||
jasmine.JQuery.matchersClass = {}
|
||||
|
||||
!function (namespace) {
|
||||
var data = {
|
||||
spiedEvents: {}
|
||||
, handlers: []
|
||||
}
|
||||
|
||||
namespace.events = {
|
||||
spyOn: function (selector, eventName) {
|
||||
var handler = function (e) {
|
||||
data.spiedEvents[jasmine.spiedEventsKey(selector, eventName)] = jasmine.util.argsToArray(arguments)
|
||||
}
|
||||
|
||||
$(selector).on(eventName, handler)
|
||||
data.handlers.push(handler)
|
||||
|
||||
return {
|
||||
selector: selector,
|
||||
eventName: eventName,
|
||||
handler: handler,
|
||||
reset: function (){
|
||||
delete data.spiedEvents[jasmine.spiedEventsKey(selector, eventName)]
|
||||
}
|
||||
}
|
||||
},
|
||||
|
||||
args: function (selector, eventName) {
|
||||
var actualArgs = data.spiedEvents[jasmine.spiedEventsKey(selector, eventName)]
|
||||
|
||||
if (!actualArgs) {
|
||||
throw "There is no spy for " + eventName + " on " + selector.toString() + ". Make sure to create a spy using spyOnEvent."
|
||||
}
|
||||
|
||||
return actualArgs
|
||||
},
|
||||
|
||||
wasTriggered: function (selector, eventName) {
|
||||
return !!(data.spiedEvents[jasmine.spiedEventsKey(selector, eventName)])
|
||||
},
|
||||
|
||||
wasTriggeredWith: function (selector, eventName, expectedArgs, env) {
|
||||
var actualArgs = jasmine.JQuery.events.args(selector, eventName).slice(1)
|
||||
if (Object.prototype.toString.call(expectedArgs) !== '[object Array]') {
|
||||
actualArgs = actualArgs[0]
|
||||
}
|
||||
return env.equals_(expectedArgs, actualArgs)
|
||||
},
|
||||
|
||||
wasPrevented: function (selector, eventName) {
|
||||
var args = data.spiedEvents[jasmine.spiedEventsKey(selector, eventName)]
|
||||
, e = args ? args[0] : undefined
|
||||
|
||||
return e && e.isDefaultPrevented()
|
||||
},
|
||||
|
||||
wasStopped: function (selector, eventName) {
|
||||
var args = data.spiedEvents[jasmine.spiedEventsKey(selector, eventName)]
|
||||
, e = args ? args[0] : undefined
|
||||
return e && e.isPropagationStopped()
|
||||
},
|
||||
|
||||
cleanUp: function () {
|
||||
data.spiedEvents = {}
|
||||
data.handlers = []
|
||||
}
|
||||
}
|
||||
}(jasmine.JQuery)
|
||||
|
||||
!function (){
|
||||
var jQueryMatchers = {
|
||||
toHaveClass: function (className) {
|
||||
return this.actual.hasClass(className)
|
||||
},
|
||||
|
||||
toHaveCss: function (css){
|
||||
for (var prop in css){
|
||||
var value = css[prop]
|
||||
// see issue #147 on gh
|
||||
;if (value === 'auto' && this.actual.get(0).style[prop] === 'auto') continue
|
||||
if (this.actual.css(prop) !== value) return false
|
||||
}
|
||||
return true
|
||||
},
|
||||
|
||||
toBeVisible: function () {
|
||||
return this.actual.is(':visible')
|
||||
},
|
||||
|
||||
toBeHidden: function () {
|
||||
return this.actual.is(':hidden')
|
||||
},
|
||||
|
||||
toBeSelected: function () {
|
||||
return this.actual.is(':selected')
|
||||
},
|
||||
|
||||
toBeChecked: function () {
|
||||
return this.actual.is(':checked')
|
||||
},
|
||||
|
||||
toBeEmpty: function () {
|
||||
return this.actual.is(':empty')
|
||||
},
|
||||
|
||||
toExist: function () {
|
||||
return this.actual.length
|
||||
},
|
||||
|
||||
toHaveLength: function (length) {
|
||||
return this.actual.length === length
|
||||
},
|
||||
|
||||
toHaveAttr: function (attributeName, expectedAttributeValue) {
|
||||
return hasProperty(this.actual.attr(attributeName), expectedAttributeValue)
|
||||
},
|
||||
|
||||
toHaveProp: function (propertyName, expectedPropertyValue) {
|
||||
return hasProperty(this.actual.prop(propertyName), expectedPropertyValue)
|
||||
},
|
||||
|
||||
toHaveId: function (id) {
|
||||
return this.actual.attr('id') == id
|
||||
},
|
||||
|
||||
toHaveHtml: function (html) {
|
||||
return this.actual.html() == jasmine.JQuery.browserTagCaseIndependentHtml(html)
|
||||
},
|
||||
|
||||
toContainHtml: function (html){
|
||||
var actualHtml = this.actual.html()
|
||||
, expectedHtml = jasmine.JQuery.browserTagCaseIndependentHtml(html)
|
||||
|
||||
return (actualHtml.indexOf(expectedHtml) >= 0)
|
||||
},
|
||||
|
||||
toHaveText: function (text) {
|
||||
var trimmedText = $.trim(this.actual.text())
|
||||
|
||||
if (text && $.isFunction(text.test)) {
|
||||
return text.test(trimmedText)
|
||||
} else {
|
||||
return trimmedText == text
|
||||
}
|
||||
},
|
||||
|
||||
toContainText: function (text) {
|
||||
var trimmedText = $.trim(this.actual.text())
|
||||
|
||||
if (text && $.isFunction(text.test)) {
|
||||
return text.test(trimmedText)
|
||||
} else {
|
||||
return trimmedText.indexOf(text) != -1
|
||||
}
|
||||
},
|
||||
|
||||
toHaveValue: function (value) {
|
||||
return this.actual.val() === value
|
||||
},
|
||||
|
||||
toHaveData: function (key, expectedValue) {
|
||||
return hasProperty(this.actual.data(key), expectedValue)
|
||||
},
|
||||
|
||||
toBe: function (selector) {
|
||||
return this.actual.is(selector)
|
||||
},
|
||||
|
||||
toContain: function (selector) {
|
||||
return this.actual.find(selector).length
|
||||
},
|
||||
|
||||
toBeMatchedBy: function (selector) {
|
||||
return this.actual.filter(selector).length
|
||||
},
|
||||
|
||||
toBeDisabled: function (selector){
|
||||
return this.actual.is(':disabled')
|
||||
},
|
||||
|
||||
toBeFocused: function (selector) {
|
||||
return this.actual[0] === this.actual[0].ownerDocument.activeElement
|
||||
},
|
||||
|
||||
toHandle: function (event) {
|
||||
var events = $._data(this.actual.get(0), "events")
|
||||
|
||||
if(!events || !event || typeof event !== "string") {
|
||||
return false
|
||||
}
|
||||
|
||||
var namespaces = event.split(".")
|
||||
, eventType = namespaces.shift()
|
||||
, sortedNamespaces = namespaces.slice(0).sort()
|
||||
, namespaceRegExp = new RegExp("(^|\\.)" + sortedNamespaces.join("\\.(?:.*\\.)?") + "(\\.|$)")
|
||||
|
||||
if(events[eventType] && namespaces.length) {
|
||||
for(var i = 0; i < events[eventType].length; i++) {
|
||||
var namespace = events[eventType][i].namespace
|
||||
|
||||
if(namespaceRegExp.test(namespace)) {
|
||||
return true
|
||||
}
|
||||
}
|
||||
} else {
|
||||
return events[eventType] && events[eventType].length > 0
|
||||
}
|
||||
},
|
||||
|
||||
toHandleWith: function (eventName, eventHandler) {
|
||||
var normalizedEventName = eventName.split('.')[0]
|
||||
, stack = $._data(this.actual.get(0), "events")[normalizedEventName]
|
||||
|
||||
for (var i = 0; i < stack.length; i++) {
|
||||
if (stack[i].handler == eventHandler) return true
|
||||
}
|
||||
|
||||
return false
|
||||
}
|
||||
}
|
||||
|
||||
var hasProperty = function (actualValue, expectedValue) {
|
||||
if (expectedValue === undefined) return actualValue !== undefined
|
||||
|
||||
return actualValue == expectedValue
|
||||
}
|
||||
|
||||
var bindMatcher = function (methodName) {
|
||||
var builtInMatcher = jasmine.Matchers.prototype[methodName]
|
||||
|
||||
jasmine.JQuery.matchersClass[methodName] = function () {
|
||||
if (this.actual
|
||||
&& (this.actual instanceof $
|
||||
|| jasmine.isDomNode(this.actual))) {
|
||||
this.actual = $(this.actual)
|
||||
var result = jQueryMatchers[methodName].apply(this, arguments)
|
||||
, element
|
||||
|
||||
if (this.actual.get && (element = this.actual.get()[0]) && !$.isWindow(element) && element.tagName !== "HTML")
|
||||
this.actual = jasmine.JQuery.elementToString(this.actual)
|
||||
|
||||
return result
|
||||
}
|
||||
|
||||
if (builtInMatcher) {
|
||||
return builtInMatcher.apply(this, arguments)
|
||||
}
|
||||
|
||||
return false
|
||||
}
|
||||
}
|
||||
|
||||
for(var methodName in jQueryMatchers) {
|
||||
bindMatcher(methodName)
|
||||
}
|
||||
}()
|
||||
|
||||
beforeEach(function () {
|
||||
this.addMatchers(jasmine.JQuery.matchersClass)
|
||||
this.addMatchers({
|
||||
toHaveBeenTriggeredOn: function (selector) {
|
||||
this.message = function () {
|
||||
return [
|
||||
"Expected event " + this.actual + " to have been triggered on " + selector,
|
||||
"Expected event " + this.actual + " not to have been triggered on " + selector
|
||||
]
|
||||
}
|
||||
return jasmine.JQuery.events.wasTriggered(selector, this.actual)
|
||||
}
|
||||
})
|
||||
this.addMatchers({
|
||||
toHaveBeenTriggered: function (){
|
||||
var eventName = this.actual.eventName
|
||||
, selector = this.actual.selector
|
||||
|
||||
this.message = function () {
|
||||
return [
|
||||
"Expected event " + eventName + " to have been triggered on " + selector,
|
||||
"Expected event " + eventName + " not to have been triggered on " + selector
|
||||
]
|
||||
}
|
||||
|
||||
return jasmine.JQuery.events.wasTriggered(selector, eventName)
|
||||
}
|
||||
})
|
||||
this.addMatchers({
|
||||
toHaveBeenTriggeredOnAndWith: function () {
|
||||
var selector = arguments[0]
|
||||
, expectedArgs = arguments[1]
|
||||
, wasTriggered = jasmine.JQuery.events.wasTriggered(selector, this.actual)
|
||||
|
||||
this.message = function () {
|
||||
if (wasTriggered) {
|
||||
var actualArgs = jasmine.JQuery.events.args(selector, this.actual, expectedArgs)[1]
|
||||
return [
|
||||
"Expected event " + this.actual + " to have been triggered with " + jasmine.pp(expectedArgs) + " but it was triggered with " + jasmine.pp(actualArgs),
|
||||
"Expected event " + this.actual + " not to have been triggered with " + jasmine.pp(expectedArgs) + " but it was triggered with " + jasmine.pp(actualArgs)
|
||||
]
|
||||
} else {
|
||||
return [
|
||||
"Expected event " + this.actual + " to have been triggered on " + selector,
|
||||
"Expected event " + this.actual + " not to have been triggered on " + selector
|
||||
]
|
||||
}
|
||||
}
|
||||
|
||||
return wasTriggered && jasmine.JQuery.events.wasTriggeredWith(selector, this.actual, expectedArgs, this.env)
|
||||
}
|
||||
})
|
||||
this.addMatchers({
|
||||
toHaveBeenPreventedOn: function (selector) {
|
||||
this.message = function () {
|
||||
return [
|
||||
"Expected event " + this.actual + " to have been prevented on " + selector,
|
||||
"Expected event " + this.actual + " not to have been prevented on " + selector
|
||||
]
|
||||
}
|
||||
|
||||
return jasmine.JQuery.events.wasPrevented(selector, this.actual)
|
||||
}
|
||||
})
|
||||
this.addMatchers({
|
||||
toHaveBeenPrevented: function () {
|
||||
var eventName = this.actual.eventName
|
||||
, selector = this.actual.selector
|
||||
this.message = function () {
|
||||
return [
|
||||
"Expected event " + eventName + " to have been prevented on " + selector,
|
||||
"Expected event " + eventName + " not to have been prevented on " + selector
|
||||
]
|
||||
}
|
||||
|
||||
return jasmine.JQuery.events.wasPrevented(selector, eventName)
|
||||
}
|
||||
})
|
||||
this.addMatchers({
|
||||
toHaveBeenStoppedOn: function (selector) {
|
||||
this.message = function () {
|
||||
return [
|
||||
"Expected event " + this.actual + " to have been stopped on " + selector,
|
||||
"Expected event " + this.actual + " not to have been stopped on " + selector
|
||||
]
|
||||
}
|
||||
|
||||
return jasmine.JQuery.events.wasStopped(selector, this.actual)
|
||||
}
|
||||
})
|
||||
this.addMatchers({
|
||||
toHaveBeenStopped: function () {
|
||||
var eventName = this.actual.eventName
|
||||
, selector = this.actual.selector
|
||||
this.message = function () {
|
||||
return [
|
||||
"Expected event " + eventName + " to have been stopped on " + selector,
|
||||
"Expected event " + eventName + " not to have been stopped on " + selector
|
||||
]
|
||||
}
|
||||
return jasmine.JQuery.events.wasStopped(selector, eventName)
|
||||
}
|
||||
})
|
||||
jasmine.getEnv().addEqualityTester(function (a, b) {
|
||||
if(a instanceof jQuery && b instanceof jQuery) {
|
||||
if(a.size() != b.size()) {
|
||||
return jasmine.undefined
|
||||
}
|
||||
else if(a.is(b)) {
|
||||
return true
|
||||
}
|
||||
}
|
||||
|
||||
return jasmine.undefined
|
||||
})
|
||||
})
|
||||
|
||||
afterEach(function () {
|
||||
jasmine.getFixtures().cleanUp()
|
||||
jasmine.getStyleFixtures().cleanUp()
|
||||
jasmine.JQuery.events.cleanUp()
|
||||
})
|
||||
}(window.jasmine, window.jQuery)
|
||||
|
||||
+function (jasmine, global) { "use strict";
|
||||
|
||||
global.readFixtures = function () {
|
||||
return jasmine.getFixtures().proxyCallTo_('read', arguments)
|
||||
}
|
||||
|
||||
global.preloadFixtures = function () {
|
||||
jasmine.getFixtures().proxyCallTo_('preload', arguments)
|
||||
}
|
||||
|
||||
global.loadFixtures = function () {
|
||||
jasmine.getFixtures().proxyCallTo_('load', arguments)
|
||||
}
|
||||
|
||||
global.appendLoadFixtures = function () {
|
||||
jasmine.getFixtures().proxyCallTo_('appendLoad', arguments)
|
||||
}
|
||||
|
||||
global.setFixtures = function (html) {
|
||||
return jasmine.getFixtures().proxyCallTo_('set', arguments)
|
||||
}
|
||||
|
||||
global.appendSetFixtures = function () {
|
||||
jasmine.getFixtures().proxyCallTo_('appendSet', arguments)
|
||||
}
|
||||
|
||||
global.sandbox = function (attributes) {
|
||||
return jasmine.getFixtures().sandbox(attributes)
|
||||
}
|
||||
|
||||
global.spyOnEvent = function (selector, eventName) {
|
||||
return jasmine.JQuery.events.spyOn(selector, eventName)
|
||||
}
|
||||
|
||||
global.preloadStyleFixtures = function () {
|
||||
jasmine.getStyleFixtures().proxyCallTo_('preload', arguments)
|
||||
}
|
||||
|
||||
global.loadStyleFixtures = function () {
|
||||
jasmine.getStyleFixtures().proxyCallTo_('load', arguments)
|
||||
}
|
||||
|
||||
global.appendLoadStyleFixtures = function () {
|
||||
jasmine.getStyleFixtures().proxyCallTo_('appendLoad', arguments)
|
||||
}
|
||||
|
||||
global.setStyleFixtures = function (html) {
|
||||
jasmine.getStyleFixtures().proxyCallTo_('set', arguments)
|
||||
}
|
||||
|
||||
global.appendSetStyleFixtures = function (html) {
|
||||
jasmine.getStyleFixtures().proxyCallTo_('appendSet', arguments)
|
||||
}
|
||||
|
||||
global.loadJSONFixtures = function () {
|
||||
return jasmine.getJSONFixtures().proxyCallTo_('load', arguments)
|
||||
}
|
||||
|
||||
global.getJSONFixture = function (url) {
|
||||
return jasmine.getJSONFixtures().proxyCallTo_('read', arguments)[url]
|
||||
}
|
||||
}(jasmine, window);
|
58
web/semantic/test/helpers/jasmine-sinon.js
Normal file
58
web/semantic/test/helpers/jasmine-sinon.js
Normal file
|
@ -0,0 +1,58 @@
|
|||
/* global jasmine */
|
||||
|
||||
'use strict';
|
||||
|
||||
(function(jasmine, beforeEach) {
|
||||
|
||||
var sinon = (typeof require === 'function' && typeof module === 'object') ? require('sinon') : window.sinon,
|
||||
spyMatchers = 'called calledOnce calledTwice calledThrice calledBefore calledAfter calledOn alwaysCalledOn calledWith alwaysCalledWith calledWithExactly alwaysCalledWithExactly calledWithMatch alwaysCalledWithMatch'.split(' '),
|
||||
i = spyMatchers.length,
|
||||
spyMatcherHash = {},
|
||||
unusualMatchers = {
|
||||
"returned": "toHaveReturned",
|
||||
"alwaysReturned": "toHaveAlwaysReturned",
|
||||
"threw": "toHaveThrown",
|
||||
"alwaysThrew": "toHaveAlwaysThrown"
|
||||
},
|
||||
|
||||
createCustomMatcher = function(arg) {
|
||||
return sinon.match(function (val) {
|
||||
return jasmine.getEnv().equals_(val, arg);
|
||||
});
|
||||
},
|
||||
|
||||
getMatcherFunction = function(sinonName, matcherName) {
|
||||
var original = jasmine.Matchers.prototype[matcherName];
|
||||
return function () {
|
||||
if (jasmine.isSpy(this.actual) && original) {
|
||||
return original.apply(this, arguments);
|
||||
}
|
||||
var sinonProperty = this.actual[sinonName];
|
||||
var args = Array.prototype.slice.call(arguments);
|
||||
|
||||
for (var i = 0; i < args.length; i++) {
|
||||
if (args[i] && (typeof args[i].jasmineMatches === 'function' || args[i] instanceof jasmine.Matchers.ObjectContaining)) {
|
||||
args[i] = createCustomMatcher(args[i]);
|
||||
}
|
||||
}
|
||||
|
||||
return (typeof sinonProperty === 'function') ? sinonProperty.apply(this.actual, args) : sinonProperty;
|
||||
};
|
||||
};
|
||||
|
||||
while(i--) {
|
||||
var sinonName = spyMatchers[i],
|
||||
matcherName = "toHaveBeen" + sinonName.charAt(0).toUpperCase() + sinonName.slice(1);
|
||||
|
||||
spyMatcherHash[matcherName] = getMatcherFunction(sinonName, matcherName);
|
||||
}
|
||||
|
||||
for (var j in unusualMatchers) {
|
||||
spyMatcherHash[unusualMatchers[j]] = getMatcherFunction(j, unusualMatchers[j]);
|
||||
}
|
||||
|
||||
beforeEach(function() {
|
||||
this.addMatchers(spyMatcherHash);
|
||||
});
|
||||
|
||||
})(jasmine, beforeEach);
|
28
web/semantic/test/helpers/jquery-events.js
vendored
Normal file
28
web/semantic/test/helpers/jquery-events.js
vendored
Normal file
|
@ -0,0 +1,28 @@
|
|||
(function($) {
|
||||
$.events = function(selector, root) {
|
||||
var s = [];
|
||||
$(selector || '*', root).addBack().each(function() {
|
||||
// the following line is the only change
|
||||
var e = $._data(this, 'events');
|
||||
if(!e) return;
|
||||
s.push(this.tagName);
|
||||
if(this.id) s.push('#', this.id);
|
||||
if(this.className) s.push('.', this.className.replace(/ +/g, '.'));
|
||||
for(var p in e) {
|
||||
var r = e[p],
|
||||
h = r.length - r.delegateCount;
|
||||
if(h)
|
||||
s.push('\n', h, ' ', p, ' handler', h > 1 ? 's' : '');
|
||||
if(r.delegateCount) {
|
||||
for(var q = 0; q < r.length; q++)
|
||||
if(r[q].selector) s.push('\n', p, ' for ', r[q].selector);
|
||||
}
|
||||
}
|
||||
s.push('\n\n');
|
||||
});
|
||||
return s.join('');
|
||||
}
|
||||
$.fn.events = function(selector) {
|
||||
return $.events(selector, this);
|
||||
}
|
||||
})(jQuery);
|
4819
web/semantic/test/helpers/sinon.js
Normal file
4819
web/semantic/test/helpers/sinon.js
Normal file
File diff suppressed because it is too large
Load diff
20
web/semantic/test/meteor/assets.js
Normal file
20
web/semantic/test/meteor/assets.js
Normal file
|
@ -0,0 +1,20 @@
|
|||
var assets = [
|
||||
'dist/themes/default/assets/images/flags.png',
|
||||
];
|
||||
|
||||
// Check that the font files are downloadable. Meteor places assets at /packages/<packageName>/.
|
||||
assets.forEach(function (path) {
|
||||
Tinytest.addAsync('image ' + path + ' is shipped', function (test, done) {
|
||||
HTTP.get('/packages/semantic_ui/' + path, function callback(error, result) {
|
||||
if (error) {
|
||||
test.fail({message: 'Image failed to load'});
|
||||
}
|
||||
else {
|
||||
test.isTrue(result.content.length > 10000, 'Image ' + path + ' could not be downloaded');
|
||||
}
|
||||
done();
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
|
16
web/semantic/test/meteor/fonts.js
Normal file
16
web/semantic/test/meteor/fonts.js
Normal file
|
@ -0,0 +1,16 @@
|
|||
// Check that the font files are downloadable. Meteor places assets at /packages/<packageName>/.
|
||||
['eot', 'otf', 'svg', 'ttf', 'woff']
|
||||
.forEach(function (extension) {
|
||||
Tinytest.addAsync(extension + ' fonts are shipped', function (test, done) {
|
||||
HTTP.get('/packages/semantic_ui/dist/themes/default/assets/fonts/icons.' + extension, function callback(error, result) {
|
||||
if (error) {
|
||||
test.fail({message: 'Font failed to load'});
|
||||
}
|
||||
else {
|
||||
test.isTrue(result.content.length > 10000, extension + ' font could not be downloaded');
|
||||
}
|
||||
done();
|
||||
});
|
||||
});
|
||||
})
|
||||
;
|
10
web/semantic/test/modules/accordion.spec.js
Normal file
10
web/semantic/test/modules/accordion.spec.js
Normal file
|
@ -0,0 +1,10 @@
|
|||
describe("UI Accordion", function() {
|
||||
|
||||
$.fn.dimmer.settings.debug = false;
|
||||
|
||||
moduleTests({
|
||||
module : 'accordion',
|
||||
element : '.ui.accordion'
|
||||
});
|
||||
|
||||
});
|
8
web/semantic/test/modules/checkbox.spec.js
Normal file
8
web/semantic/test/modules/checkbox.spec.js
Normal file
|
@ -0,0 +1,8 @@
|
|||
describe("UI Checkbox", function() {
|
||||
|
||||
moduleTests({
|
||||
module : 'checkbox',
|
||||
element : '.ui.checkbox'
|
||||
});
|
||||
|
||||
});
|
8
web/semantic/test/modules/dropdown.spec.js
Normal file
8
web/semantic/test/modules/dropdown.spec.js
Normal file
|
@ -0,0 +1,8 @@
|
|||
describe("UI Dropdown", function() {
|
||||
|
||||
moduleTests({
|
||||
module : 'dropdown',
|
||||
element : '.ui.dropdown'
|
||||
});
|
||||
|
||||
});
|
10
web/semantic/test/modules/modal.spec.js
Normal file
10
web/semantic/test/modules/modal.spec.js
Normal file
|
@ -0,0 +1,10 @@
|
|||
describe("UI Modal", function() {
|
||||
|
||||
$.fn.dimmer.settings.debug = false;
|
||||
|
||||
moduleTests({
|
||||
module : 'modal',
|
||||
element : '.ui.modal'
|
||||
});
|
||||
|
||||
});
|
218
web/semantic/test/modules/module.spec.js
Normal file
218
web/semantic/test/modules/module.spec.js
Normal file
|
@ -0,0 +1,218 @@
|
|||
|
||||
function moduleTests(ui) {
|
||||
var
|
||||
module = ui.module,
|
||||
element = ui.element,
|
||||
singleton = ui.singleton,
|
||||
name = $.fn[module].settings.name,
|
||||
|
||||
testValue = 'Test',
|
||||
fixtures = jasmine.getFixtures(),
|
||||
|
||||
originalSettings,
|
||||
$modules,
|
||||
$oneModule,
|
||||
$module,
|
||||
$clone
|
||||
;
|
||||
|
||||
// set fixture path
|
||||
fixtures.fixturesPath = 'base/test/fixtures/';
|
||||
|
||||
// disable debug
|
||||
$.fn[module].settings.debug = false;
|
||||
$.fn[module].settings.performance = false;
|
||||
$.fn[module].settings.verbose = false;
|
||||
|
||||
|
||||
beforeEach(function() {
|
||||
// load fixtures
|
||||
fixtures.load(module + '.html');
|
||||
// save settings
|
||||
originalSettings = $.fn[module].settings;
|
||||
|
||||
// module available in scope
|
||||
$module = $(element);
|
||||
|
||||
// one module available in fixture
|
||||
if($module.size() == 1) {
|
||||
$oneModule = $module;
|
||||
$clone = $module.clone().appendTo( $(sandbox()) );
|
||||
$modules = $clone.add($module);
|
||||
}
|
||||
// multiple modules available in fixture
|
||||
else {
|
||||
$modules = $(element);
|
||||
$clone = $module.eq(1);
|
||||
$oneModule = $modules.first();
|
||||
}
|
||||
|
||||
});
|
||||
|
||||
afterEach(function() {
|
||||
// restore settings
|
||||
$.fn[module].settings = originalSettings;
|
||||
// remove element
|
||||
$(element).remove();
|
||||
});
|
||||
|
||||
/*******************************
|
||||
Module
|
||||
*******************************/
|
||||
|
||||
/*-------------------
|
||||
Instantiation
|
||||
--------------------*/
|
||||
describe('Module', function() {
|
||||
|
||||
it("allows chaining when no settings returned", function() {
|
||||
var $chain = $modules[module]();
|
||||
expect($chain).toExist();
|
||||
expect($chain.size()).toBe($modules.size());
|
||||
});
|
||||
|
||||
it("returns a string when one setting returned", function() {
|
||||
var result = $oneModule[module]('setting', 'name');
|
||||
expect(typeof result).toBe('string');
|
||||
});
|
||||
|
||||
it("returns an array when multiple settings returned", function() {
|
||||
var result = $modules[module]('setting', 'name');
|
||||
expect( $.isArray(result) ).toBeTruthy();
|
||||
});
|
||||
|
||||
it("has an instance in metadata after init", function() {
|
||||
$oneModule[module]();
|
||||
expect($module).toHaveData('module-' + module);
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
/*-------------------
|
||||
Settings
|
||||
--------------------*/
|
||||
|
||||
describe('Settings', function() {
|
||||
|
||||
it("clears settings on re-init", function() {
|
||||
$oneModule[module]({
|
||||
name: testValue
|
||||
});
|
||||
|
||||
var retrievedValue = $oneModule[module]('setting', 'name');
|
||||
expect(retrievedValue).toBe(testValue);
|
||||
|
||||
// reinit
|
||||
$oneModule[module]();
|
||||
retrievedValue = $oneModule[module]('setting', 'name');
|
||||
expect(retrievedValue).toBe(name);
|
||||
});
|
||||
|
||||
it("allows default settings to be changed", function() {
|
||||
$.fn[module].settings.name = testValue;
|
||||
$oneModule[module]();
|
||||
|
||||
var retrievedValue = $oneModule[module]('setting', 'name');
|
||||
$.fn[module].settings.name = name;
|
||||
|
||||
expect(retrievedValue).toBe(testValue);
|
||||
});
|
||||
|
||||
it("allows settings to be changed during init", function() {
|
||||
$oneModule[module]({
|
||||
name: testValue
|
||||
});
|
||||
|
||||
var retrievedValue = $oneModule[module]('setting', 'name');
|
||||
|
||||
expect(retrievedValue).toBe(testValue);
|
||||
});
|
||||
|
||||
it("allows settings to be changed during runtime", function() {
|
||||
$oneModule[module]();
|
||||
|
||||
var retrievedValue = $oneModule[module]('setting', 'name');
|
||||
|
||||
expect(retrievedValue).toBe(name);
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
/*-------------------
|
||||
Groups
|
||||
--------------------*/
|
||||
|
||||
if(!singleton) {
|
||||
|
||||
describe('Group Contamination', function() {
|
||||
|
||||
it("creates settings for all instances", function() {
|
||||
$modules[module]('setting', 'name', testValue);
|
||||
|
||||
var retrievedValue = $oneModule[module]('setting', 'name');
|
||||
var clonedSetting = $clone[module]('setting', 'name');
|
||||
|
||||
expect(retrievedValue).toBe(testValue);
|
||||
expect(clonedSetting).toBe(testValue);
|
||||
|
||||
$oneModule[module]({
|
||||
'name': testValue
|
||||
});
|
||||
|
||||
expect(retrievedValue).toBe(testValue);
|
||||
expect(clonedSetting).toBe(testValue);
|
||||
|
||||
});
|
||||
|
||||
it("does not change other elements settings when changing one element", function() {
|
||||
$modules[module]();
|
||||
$oneModule[module]('setting', 'name', testValue);
|
||||
|
||||
var retrievedValue = $oneModule[module]('setting', 'name');
|
||||
var clonedSetting = $clone[module]('setting', 'name');
|
||||
|
||||
expect(retrievedValue).toBe(testValue);
|
||||
expect(clonedSetting).toBe(name);
|
||||
|
||||
});
|
||||
|
||||
it("does not change other elements when re-initalized", function() {
|
||||
$modules[module]();
|
||||
|
||||
$oneModule[module]({
|
||||
'name': testValue
|
||||
});
|
||||
|
||||
var retrievedValue = $oneModule[module]('setting', 'name');
|
||||
var clonedSetting = $clone[module]('setting', 'name');
|
||||
|
||||
expect(retrievedValue).toBe(testValue);
|
||||
expect(clonedSetting).toBe(name);
|
||||
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
/*-------------------
|
||||
Destroy
|
||||
--------------------*/
|
||||
describe('Destroy', function() {
|
||||
|
||||
it("removes all events from page", function() {
|
||||
$module[module]('destroy');
|
||||
if($.events().length > 0) {
|
||||
dump($.events());
|
||||
}
|
||||
expect($.events().length).toBe(0);
|
||||
});
|
||||
|
||||
it("removes instance metadata", function() {
|
||||
$module[module]('destroy');
|
||||
expect( $module.data('module-'+ module) ).toBe(undefined);
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
}
|
8
web/semantic/test/modules/popup.spec.js
Normal file
8
web/semantic/test/modules/popup.spec.js
Normal file
|
@ -0,0 +1,8 @@
|
|||
xdescribe("UI Popup", function() {
|
||||
|
||||
moduleTests({
|
||||
module : 'popup',
|
||||
element : 'i.icon'
|
||||
});
|
||||
|
||||
});
|
8
web/semantic/test/modules/search.spec.js
Normal file
8
web/semantic/test/modules/search.spec.js
Normal file
|
@ -0,0 +1,8 @@
|
|||
xdescribe("UI Search", function() {
|
||||
|
||||
moduleTests({
|
||||
module : 'search',
|
||||
element : '.ui.search'
|
||||
});
|
||||
|
||||
});
|
8
web/semantic/test/modules/shape.spec.js
Normal file
8
web/semantic/test/modules/shape.spec.js
Normal file
|
@ -0,0 +1,8 @@
|
|||
describe("UI Shape", function() {
|
||||
|
||||
moduleTests({
|
||||
module : 'shape',
|
||||
element : '.ui.shape'
|
||||
});
|
||||
|
||||
});
|
8
web/semantic/test/modules/sidebar.spec.js
Normal file
8
web/semantic/test/modules/sidebar.spec.js
Normal file
|
@ -0,0 +1,8 @@
|
|||
describe("UI Rating", function() {
|
||||
|
||||
moduleTests({
|
||||
module : 'rating',
|
||||
element : '.ui.rating'
|
||||
});
|
||||
|
||||
});
|
9
web/semantic/test/modules/tab.spec.js
Normal file
9
web/semantic/test/modules/tab.spec.js
Normal file
|
@ -0,0 +1,9 @@
|
|||
xdescribe("UI Tab", function() {
|
||||
|
||||
moduleTests({
|
||||
module : 'tab',
|
||||
element : '.ui.menu .item',
|
||||
singleton : true
|
||||
});
|
||||
|
||||
});
|
8
web/semantic/test/modules/transition.spec.js
Normal file
8
web/semantic/test/modules/transition.spec.js
Normal file
|
@ -0,0 +1,8 @@
|
|||
xdescribe("UI Transition", function() {
|
||||
|
||||
moduleTests({
|
||||
module : 'transition',
|
||||
element : '.ui.image'
|
||||
});
|
||||
|
||||
});
|
8
web/semantic/test/modules/video.spec.js
Normal file
8
web/semantic/test/modules/video.spec.js
Normal file
|
@ -0,0 +1,8 @@
|
|||
describe("UI Video", function() {
|
||||
|
||||
moduleTests({
|
||||
module : 'video',
|
||||
element : '.ui.video'
|
||||
});
|
||||
|
||||
});
|
Reference in a new issue