- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有人以前见过这个并且知道它的含义吗?
14:13:43 PhantomJS 1.9.8 (Linux) ERROR
14:13:43 Error: Cannot have setup/teardown in describe for: athena-vertical-expanding-carousel
14:13:43 at /home/jenkins/workspace/Shared_GD_Build/frontend/test/js/test.js:40
我有一组非常相似的测试,它们正在工作,但可能有问题:
define([
"jquery",
"underscore",
"common/athena/vertical-expanding-carousel"
], function ($, _, AthVertExpandingCarousel) {
describe("common/", function () {
describe("athena/", function () {
describe("athena-vertical-expanding-carousel", function () {
var $fixture,
carousel,
sandbox;
beforeEach(function () {
sandbox = sinon.sandbox.create();
$fixture = $([
"<div id='vert-carousel-test-outer' class='generic_container'>",
"<div id='vert-carousel-test' class='js-vertCarouselMainContainer" +
" vertCarouselMainContainer carousel'>",
" <ol class='js-carousel-items'>",
" <li class='selected'>",
" <div><a href='#'><img data-lazy='/static-mock/empty.png' /></a></div>",
" </li>",
" <li>",
" <div><a href='#'><img data-lazy='/static-mock/empty.png' /></a></div>",
" </li>",
" <li>",
" <div><a href='#'><img data-lazy='/static-mock/empty.png' /></a></div>",
" </li>",
" <li>",
" <div><a href='#'><img data-lazy='/static-mock/empty.png' /></a></div>",
" </li>",
" <li>",
" <div><a href='#'><img data-lazy='/static-mock/empty.png' /></a></div>",
" </li>",
" <li>",
" <div><a href='#'><img data-lazy='/static-mock/empty.png' /></a></div>",
" </li>",
" <li>",
" <div><a href='#'><img data-lazy='/static-mock/empty.png' /></a></div>",
" </li>",
" <li>",
" <div><a href='#'><img data-lazy='/static-mock/empty.png' /></a></div>",
" </li>",
" <li>",
" <div><a href='#'><img data-lazy='/static-mock/empty.png' /></a></div>",
" </li>",
" <li>",
" <div><a href='#'><img data-lazy='/static-mock/empty.png' /></a></div>",
" </li>",
" <li>",
" <div><a href='#'><img data-lazy='/static-mock/empty.png' /></a></div>",
" </li>",
" </ol>",
"</div>",
"<div class='paginator-container' id='paginator-container'>",
" <div class='js-up-down-controls'>",
" <div class='js-up-controls'>",
" </div>",
" <div class='js-down-controls'>",
" </div>",
" </div>",
"</div>",
"</div>"
].join("\n")).appendTo($("#fixtures-visible"));
});
afterEach(function () {
$fixture.remove();
sandbox.restore();
if (carousel) {
carousel.remove();
}
});
describe("base case", function () {
it("should not have any new classes indicating initialization if a bad " +
"selector is sent", function () {
var $vertCarouselContainer = $("#vert-carousel-test"),
$upDownControls = $vertCarouselContainer.parent().find(".js-up-down-controls");
$vertCarouselContainer.addClass("js-vertical-carousel-main-container");
carousel = AthVertExpandingCarousel.init($("nada"),
{maxRows: 5});
expect($upDownControls).to
.not
.have.$class("atTop").and
.have.$class("atBottom");
});
it("should have class of atTop and not atBottom in controlls after " +
"being initialized", function () {
var $vertCarouselContainer = $("#vert-carousel-test"),
$upDownControls = $vertCarouselContainer.parent().find(".js-up-down-controls");
$vertCarouselContainer.addClass("js-vertical-carousel-main-container");
carousel = AthVertExpandingCarousel.init($vertCarouselContainer,
{maxRows: 5});
expect($upDownControls)
.to.have.$class("atTop").and
.to.not.have.$class("atBottom");
});
// We may add an init option to start with more than one row,
// but for now we start at 1 row
it("should have class of vertPages1 after being initialized", function () {
var $vertCarouselContainer = $("#vert-carousel-test");
$vertCarouselContainer.addClass("js-vertical-carousel-main-container");
carousel = AthVertExpandingCarousel.init($vertCarouselContainer,
{maxRows: 5});
expect($vertCarouselContainer)
.to.have.$class("vertPages1");
});
it("should have class of vertPages2 and lose the the atTop class " +
"in controls after init and a downclick", function () {
var $vertCarouselContainer = $("#vert-carousel-test"),
$upDownControls = $vertCarouselContainer.parent().find(".js-up-down-controls");
$vertCarouselContainer.addClass("js-vertical-carousel-main-container");
carousel = AthVertExpandingCarousel.init($vertCarouselContainer,
{maxRows: 5});
$upDownControls.find(".js-down-controls").click();
expect($vertCarouselContainer)
.to.have.$class("vertPages2").and
.to.not.have.$class("atTop");
});
it("should have class of atTop and not the atBottom class " +
"after init and an upCLick", function () {
var $vertCarouselContainer = $("#vert-carousel-test"),
$upDownControls = $vertCarouselContainer.parent().find(".js-up-down-controls");
$vertCarouselContainer.addClass("js-vertical-carousel-main-container");
carousel = AthVertExpandingCarousel.init($vertCarouselContainer,
{maxRows: 5});
$upDownControls.find(".js-up-controls").click();
expect($upDownControls)
.to.have.$class("atTop").and
.to.not.have.$class("atBottom");
});
it("should have class of vertPages1 and data value of 1 for vertCarSize " +
"after init and an upCLick", function () {
var $vertCarouselContainer = $("#vert-carousel-test"),
$upDownControls = $vertCarouselContainer.parent().find(".js-up-down-controls");
$vertCarouselContainer.addClass("js-vertical-carousel-main-container");
carousel = AthVertExpandingCarousel.init($vertCarouselContainer,
{maxRows: 5});
$upDownControls.find(".js-up-controls").click();
expect($vertCarouselContainer)
.to.have.$class("vertPages1");
});
it("should have class of vertPages3 and data value of 3 for vertCarSize " +
"after init and TWO downClicks", function () {
var $vertCarouselContainer = $("#vert-carousel-test"),
$upDownControls = $vertCarouselContainer.parent().find(".js-up-down-controls");
$vertCarouselContainer.addClass("js-vertical-carousel-main-container");
carousel = AthVertExpandingCarousel.init($vertCarouselContainer,
{maxRows: 5});
$upDownControls.find(".js-down-controls").click().click();
expect($vertCarouselContainer)
.to.have.$class("vertPages3");
});
it("should have class of atTop and not atBottom after being initialized, " +
"a downclick and an upclick", function () {
var $vertCarouselContainer = $("#vert-carousel-test"),
$upDownControls = $vertCarouselContainer.parent().find(".js-up-down-controls");
$vertCarouselContainer.addClass("js-vertical-carousel-main-container");
carousel = AthVertExpandingCarousel.init($vertCarouselContainer,
{maxRows: 5});
$upDownControls.find(".js-down-controls").click();
$upDownControls.find(".js-up-controls").click();
expect($upDownControls)
.to.have.$class("atTop").and
.to.not.have.$class("atBottom");
});
it("should have class of atBottom and not atTop after being initialized w " +
"max of 3 rows and two downclicks", function () {
var $vertCarouselContainer = $("#vert-carousel-test"),
$upDownControls = $vertCarouselContainer.parent().find(".js-up-down-controls");
$vertCarouselContainer.addClass("js-vertical-carousel-main-container");
carousel = AthVertExpandingCarousel.init($vertCarouselContainer,
{maxRows: 3});
$upDownControls.find(".js-down-controls").click().click();
expect($upDownControls)
.to.have.$class("atBottom").and
.to.not.have.$class("atTop");
});
it("should have class of atBottom and not atTop after being initialized w max " +
"of 3 rows and three downclicks", function () {
var $vertCarouselContainer = $("#vert-carousel-test"),
$upDownControls = $vertCarouselContainer.parent().find(".js-up-down-controls");
$vertCarouselContainer.addClass("js-vertical-carousel-main-container");
carousel = AthVertExpandingCarousel.init($vertCarouselContainer,
{maxRows: 3});
$upDownControls.find(".js-down-controls").click().click();
$upDownControls.find(".js-down-controls").click(); // one too many
expect($upDownControls)
.to.have.$class("atBottom").and
.to.not.have.$class("atTop");
});
it("should have class of atBottom and not atTop after being initialized w NO MAX " +
"rows and three downclicks but not at two downclicks", function () {
var $vertCarouselContainer = $("#vert-carousel-test"),
$upDownControls = $vertCarouselContainer.parent().find(".js-up-down-controls");
$vertCarouselContainer.addClass("js-vertical-carousel-main-container");
carousel = AthVertExpandingCarousel.init($vertCarouselContainer, {});
$upDownControls.find(".js-down-controls").click().click();
expect($upDownControls)
.to.not.have.$class("atBottom").and
.to.have.$class("atTop");
$upDownControls.find(".js-down-controls").click();
expect($upDownControls)
.to.have.$class("atBottom").and
.to.not.have.$class("atTop");
});
it("should have data value of vertCarSize=4 after being initialized w NO MAX " +
"rows and three downclicks but only 3 after two down clicks", function () {
var $vertCarouselContainer = $("#vert-carousel-test"),
$upDownControls = $vertCarouselContainer.parent().find(".js-up-down-controls");
$vertCarouselContainer.addClass("js-vertical-carousel-main-container");
carousel = AthVertExpandingCarousel.init($vertCarouselContainer, {});
$upDownControls.find(".js-down-controls").click().click();
expect($vertCarouselContainer).to.have.$class("vertPages3");
$upDownControls.find(".js-down-controls").click();
expect($vertCarouselContainer)
.to.have.$class("vertPages4");
});
it("should have data value of vertCarSize=4 after being initialized w NO SECOND PARAM " +
"rows and 3 downclicks but only three after 2 down clicks", function () {
var $vertCarouselContainer = $("#vert-carousel-test"),
$upDownControls = $vertCarouselContainer.parent().find(".js-up-down-controls");
$vertCarouselContainer.addClass("js-vertical-carousel-main-container");
carousel = AthVertExpandingCarousel.init($vertCarouselContainer);
$upDownControls.find(".js-down-controls").click().click();
expect($vertCarouselContainer).to.have.$class("vertPages3");
$upDownControls.find(".js-down-controls").click();
expect($vertCarouselContainer)
.to.have.$class("vertPages4");
});
it("should have startTransition and then transitionComplete as a class after leaving " +
"atTop", function () {
var $vertCarouselContainer = $("#vert-carousel-test"),
$upDownControls = $vertCarouselContainer.parent().find(".js-up-down-controls");
sandbox.useFakeTimers();
$vertCarouselContainer.addClass("js-vertical-carousel-main-container");
carousel = AthVertExpandingCarousel.init($vertCarouselContainer, {});
$upDownControls.find(".js-down-controls").click();
expect($upDownControls).to.have.$class("startTransition");
expect($upDownControls).to.not.have.$class("transitionComplete");
expect($upDownControls).to.not.have.$class("atTop");
sandbox.clock.tick(1750);
expect($upDownControls).to.have.$class("transitionComplete");
expect($upDownControls).to.not.have.$class("startTransition");
});
it("should have startTransition and then transitionComplete as a class after leaving " +
"atBottom", function () {
var $vertCarouselContainer = $("#vert-carousel-test"),
$upDownControls = $vertCarouselContainer.parent().find(".js-up-down-controls");
sandbox.useFakeTimers();
$vertCarouselContainer.addClass("js-vertical-carousel-main-container");
carousel = AthVertExpandingCarousel.init($vertCarouselContainer, {maxRows: 2});
$upDownControls.find(".js-down-controls").click().click();
sandbox.clock.tick(1750);
$upDownControls.find(".js-up-controls").click();
expect($upDownControls).to.have.$class("startTransition");
expect($upDownControls).to.not.have.$class("transitionComplete");
expect($upDownControls).to.not.have.$class("atBottom");
sandbox.clock.tick(1750);
expect($upDownControls).to.have.$class("transitionComplete");
expect($upDownControls).to.not.have.$class("startTransition");
});
});
});
});
});
});
最佳答案
一位同事帮助我意识到我在两个不同的 .spec 文件中使用了相同的“描述”字符串:
describe("athena-vertical-expanding-carousel", function () {
我不知道 phantom、jenkins 等可以配置得如此严格以防止重复标签,但这是有道理的。
我无法找到针对此确切错误的 stackoverflow 问题,因此我希望这会对某些人有所帮助......
关于javascript - PhantomJS:无法在描述中进行设置/拆卸,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34300707/
在一个环境中,我有 pandas 版本 0.17.0 和 numpy 版本 1.10.1。在另一个环境中,我有 pandas 版本 0.18.1 和 numpy 版本 1.10.4。 我运行这段代码
This question already has answers here: Default stringify for objects, equivalent to Java's toString
我一直在尝试为我的profile命令嵌入设置一个人们可以更改的简历。我认为它应该有效,但我的代码似乎有问题。 相关代码如下: const PREFIX = '!'; var bio = {}; cli
我正在尝试获取网站图标、网站标题和外部 URL 列表的描述,最好使用 jquery。我已经成功地为我的网址同步了谷歌的图标服务,任何人都可以阐明如何实现网站标题和描述吗?这是我到目前为止获得图标的内容
我在尝试运行代码时收到错误。找不到问题出在哪里。我可能遗漏了一些小细节,如果您能纠正它那就太好了。 计算Servlet import java.io.IOException; impo
我的数据库中有两个字段,一个是描述(TEXT),另一个是short_desc(VARCHAR-200)。 当我显示搜索结果时,我显然使用了short_desc,当有人点击该项目时,他们会得到完整的描述
当我尝试通过ajax和Jquery调用 Controller 上的save方法时,我正在使用Spring MVC、Jquery、Hibernate和tomcat。单击“保存”按钮时,我在 tomcat
我试图使用describe()来获取一些描述性统计数据,但获取了应该是数字的nan值。 我尝试使用 axis=0 或 axis=1,而 axis=1 产生了正确的数值,但这不是正确的数值我需要; ax
我有超过 1 亿个字符串要存储在文件系统中。与字符串 (~255Chars utf8) 一起,将有两个日期和一些定义其属性的整数值。 我可以将它们放在一个 CSV 文件中,但它会很大。我可以将几个较小
有没有办法将 JavaScript 合并到 Jenkins 顶部的描述字段中? 每当我添加脚本标签时,当您查看源代码时,它都会被 Jenkins 删除。 如果有人有建议或方向指出我,那就太好了。
您如何获得 SEH 的名称和/或描述?异常无需必须将字符串硬编码到您的应用程序中? 我尝试使用 FormatMessage(),但它有时会截断消息,即使您指定忽略插入也是如此: __asm { //
如果我在 MySQL 中使用 CREATE TRIGGER 语法创建一个触发器,我该如何附加注释来描述它?我的意思是在声明中或之后对我来说是一样的。 我想不通。对于表格,您可以在声明末尾添加 COMM
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 8 年前。 Improve
当开发多媒体应用或者游戏应用的时候,需要使用音量控制键来设置程序的音量大小。在Android系统中有多中音频流,通过Activity中的函数 setVolumeControlStream(int s
Slick DSL 允许通过两种方式在表中创建可选字段。 对于这个案例类: case class User(id: Option[Long] = None, fname: String, lname:
如果不属于默认命名空间,我如何描述 pod 信息。使用默认命名空间我没有任何问题。 但我想获得与命名空间对齐的特定 pod 的信息。 但是,当我想描述我可以制作的同一个 pod 时,请参阅 我尝试使用
在我使用过的几乎所有 vim 副本中,程序都会在替换文本后给出更改的描述。 (例如,将显示类似“20 行 92 个替换”之类的内容。) 我现在正在使用默认情况下不这样做的 vim 副本。 是否有一个简
我正在编写规范,需要描述一些 JSON 对象。单独的文本和选项卡往往会使大型 JSON 变得过于困惑。是否有任何在线(最好)工具可以创建类似于 http://www.json.org/ 上的图表的工具
我正在尝试通过 DNS 将我的 Kubernetes 部署连接在一起。 我有一个 Java (Spring Boot) 部署和一个 javascript (node.js) 部署,两者都通过默认的 C
我只是在学习 WebGL 图形编程。 我正在检查包含该语句的某人的代码 // multiply the position by the matrix. gl_Position = vec4((u_ma
我是一名优秀的程序员,十分优秀!