- 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/
我正在尝试开始使用 Mermaid CLI,但是当我尝试针对我的源文件运行它时,它说找不到 phantomjs。 (我运行的是 Win 7 64。) C:\Users\Chris\Documents>
我正在使用PhantomJS来调用网页,如下所示: page.open('http://example.com', function (s) { console.log(page.content)
如果有这样的功能,我需要更改Phantomjs自动清除缓存的默认时间。有什么想法吗? 最佳答案 应该是您正在寻找的功能: https://github.com/ariya/phantomjs/issu
我想从我的程序运行 PhantomJs 脚本,但由于脚本可能不是我写的,我需要确保 PhantomJs 在执行完成或因任何原因(例如无效语法、超时、 ETC)。到目前为止,我读到的所有内容都说你必须始
在 Package JSON 中,我尝试了许多不同版本的 karma-phantomjs-launcher、phantomjs,包括 phantomjs-prebuilt。 当前包 JSON “开发依
我的脚本有一些语法错误,但 PhantomJS 没有显示任何错误,而是没有显示任何内容。如果脚本有错误,为什么 Phantom JS 不显示解析错误? 在以下 PhantomJS 脚本(通过 Wind
我有一些需要填写的动态输入表单。问题是要填写表格,我需要访问另一个页面以获取取决于上一页输入的数据。因此,在我获得数据然后返回表单后,表单已经更改,因此我需要在获取数据时保持该表单打开。那么问题是如何
PhantomJS 在为我捕获网页到图像文件方面做得很好。我正在使用基于 rasterize.js 的脚本。 但是,对于某些固定大小的 Web 元素,我需要生成的图像与 Web 元素的大小相匹配。 例
我正在将 PhantomJS headless 浏览器集成到我的一个项目中(目前使用 1.6 版)。在大多数情况下,它在完成我需要完成的工作方面做得很好。但是,WebPage.open() 调用工作方
是否可以在page.evaluate中传递变量? function myFunction(webpage, arg1, arg2){ var page = require('webpage').cre
有没有办法始终如一地检测 PhantomJS/CasperJS?我一直在处理用它构建的一系列恶意垃圾邮件机器人,并且能够根据某些行为基本上阻止它们,但是我很好奇是否有一种坚如磐石的方法来了解 Casp
有没有办法拦截资源请求并直接从处理程序给出响应?像这样的事情: page.onRequest(function(request){ request.reply({data: 123}); });
phantomjs 有配置 loadImage, 但我想要更多, 如何控制phantomjs跳过下载某种资源, 比如css等... ===== 好消息:已添加此功能。 https://code.goo
我正在尝试在 PhantomJS (2.1.1) 的 page.evaulate() 调用中使用 WebSocket。当尝试连接到 WebSocket 服务器时,出现以下错误: 安全错误:DOM 异常
我正在使用 PhantomJS 1.8,但遇到了一个限制——您无法指定它用于磁盘缓存的目录。我将其添加到他们的问题跟踪系统中,但由于以前没有它,所以我不希望它很快添加。 因此,我正在寻找解决此限制的方
我想渲染一个仅在用户滚动页面时加载图像的页面。仅设置 page.scrollPosition 没有任何效果。我需要一些可以随时间改变滚动位置的东西。 最佳答案 不确定这是否是最好的方法,但它确实有效。
我正在尝试使用 PhantomJS 设置远程调试,但运气不佳。我按照 https://github.com/ariya/phantomjs/wiki/Troubleshooting 上的说明进行操作。
在 PhantomJS 中,webpage.open 会使用状态参数设置为“成功”或“失败”的回调。根据文档,如果没有发生网络错误,则“成功”,否则“失败”。有没有办法查看导致失败的底层网络错误? 当
有什么方法可以使用 phantomjs 请求资源并能够到达响应的主体吗? 最佳答案 更新:关于“获取并使用所有其他资源(如图像、CSS、字体等)做某事”的其他可能含义,我最近在博客上写了 how to
在运行 PhantomJS 提供的 rasterize.js 示例时,我发现我必须等待 20 秒或更长时间才能生成网页图像。 有没有可能在不消耗大量资源的情况下加快速度的方法?我基本上希望快速生成从加
我是一名优秀的程序员,十分优秀!