So sánh nhỏ giữa Behat vs Casper trong Drupal 7 năm 2015

So sánh nhỏ giữa Behat vs Casper trong Drupal 7 năm 2015

In my previous blog post Behat - The Right Way I made a statement that I think Behat was a better choice for writing tests even for the frontend. Some good arguments were raised in favor of CasperJS.

@amitaibu @juampy72 it boils down to this: I'm a frontend dev. Writing PHP is something I avoid whenever possible.

— Chris Ruppel (@rupl) November 19, 2014

I believe my comparison was wrong in the sense it was lacking the key point to Behat's stength for us. It's not really about "Behat vs. Casper". The proper comparison should have been "Behat vs. Casper - With a Drupal backend"

Behat vs. Casper

And here's the key difference: With Behat you can interact with Drupal's API even when testing using PhantomJS. That is a lot of testing power!

CasperJS knows your site from the browser side. It has no knowledge of the internals of your Drupal site. If you would like to access a node with the title "My article", you would probably hardcode the URL in your test:

var casper = require('casper').create();

casper.start('', function() {

In Behat on the other hand you could write:

When I visit content "New article"

This would be translated to some code that will query Drupal to find the node by its title, and then redirect there.


This is obviously just a simple example. Changing variables, clearing cache,cleaning up before or after each scenario are easily done using Drupal's API via Behat, while still providing you the full capabilities of PhantomJS. Features like such as taking a screenshot of the page after a failed step - to see exactly what PhantomJS "sees".

Even though Behat is written in PHP we can mimic the functions CasperJS provides, such as waiting for an element to appear.

Boilerplate code

I think by now you know that part of The Gizra Way practices is providing a working example that you can try yourself, right?

Here's an example repository you can clone into any existing Drupal installation. Follow the README to setup the system - it shouldn't take too long and it's worth the effort.

The single test in the repo is looking for a node with the title "New article". Assuming your site doesn't have such a node, executing the test with./bin/behat will result with a failing test.

Go ahead and add a new content called "New article".

Congrats, your PhantomsJS test now works.

Now add step that will fail, e.g.

Then I wait for text "behat" to "appear"

The test will fail, and Behat will create a screenshot that you can look at, and understand why it failed. Nice, huh?

Bạn thấy bài viết này như thế nào?: 
No votes yet
Ảnh của Tommy Tran

Tommy Tran owner Express Magazine

Drupal Developer having 9+ year experience, implementation and having strong knowledge of technical specifications, workflow development. Ability to perform effectively and efficiently in team and individually. Always enthusiastic and interseted to study new technologies

  • Skype ID: tthanhthuy
  • Phone/Zalo: (+84) 944 225 212
  • WhatsApp: (+84) 944 225 212
  • Line Messenger: (+84) 944 225 212
  • Email: [email protected]
  • Telegram Messenger: https:/

Tìm kiếm bất động sản





Dich vu khu trung tphcm

Dich vu diet chuot tphcm

Dich vu diet con trung

Quảng Cáo Bài Viết

Giới thiệu tốc độ Drupal website với cloudflare

Giới thiệu tốc độ Drupal website với cloudflare

Cloudflare claims that can boost the speed of a website. But how much benefit can a site get? I am using Cloudflare for some drupal sites

Drupal 8: quá tuyệt vời nhưng quá phức tạp

Drupal 8: quá tuyệt vời nhưng quá phức tạp

I'm happy that we have a real framework underneath Drupal now, one that doesn't assume the whole world is complete HTML pages rendered and sent all at once.

Hoàng tử Ả Rập đầu tư mạnh vào Twitter

Hoàng tử Ả Rập đầu tư mạnh vào Twitter

Hoàng tử Alweleed Bin Talal của Ả Rập Saudi đã mua 300 triệu cổ phần của Twitter, trở thành cổ đông chiến lược của "tiểu blog".

Wordpress Freelancer


Wordpress Freelancer