frotnend developer @ simplabs
https://lolma.us
https://github.com/lolmaus
https://simplabs.com
assert.isEqual(actual, expected)expect(actual).to.equal(expected)actual.should.equal(expected)
As an anonymous user,
When I visit the login page,
Fill valid credentials
And submit the login form,
Then I should be logged in
And I should be on my profile
User stories:
«The Inmates Are Running the Asylum» by Alan Cooper
tests/acceptance/blog.feature Syntax is called "Gherkin"
Feature: The blog
Scenario: Visiting the blog with posts
    Given there are 3 posts in the database
    When I visit the blog page
    Then I should see 3 posts
    And I should not see the empty blog message
    
Scenario: Visiting an empty blog
    Given there are 0 blog posts in the database
    When I visit the blog page
    Then I should see 0 posts
    And I should see the empty blog messageWhen I visit the blog page
Then I should see 3 postsimport { find, visit } from '@ember/test-helpers';
export default {
  'When I visit the blog page' () {
    return visit('/blog');
  },
  
  'Then I should see 3 posts' () {
    const posts = find('.post');
    this.assert.equals(posts.length, 3);
  },
}import { find, visit } from '@ember/test-helpers';
export default {
  'When I visit the blog page' () {
    return visit('/blog');
  },
  
  'Then I should see (\\d+) posts' (countStr) {
    const posts = find('.post');
    const countInt = parseInt(countStr, 10);
    this.assert.equals(posts.length, countInt);
  }
}import { find, visit } from '@ember/test-helpers';
export default {
  'When I visit the blog page' () {
    return visit('/blog');
  },
  
  'Then I should see $number posts' (count) {
    const posts = find('.post');
    this.assert.equals(posts.length, count);
  }
}
tests/acceptance/blog.feature
tests/cucumber/steps.js
Then the declaration of independence should say: 
  ---
  The unanimous Declaration of the thirteen united States of America,
  When in the Course of human events, it becomes necessary for one people
  to dissolve the political bands which have connected them with another,
  and to assume among the powers of the earth, the separate and equal
  station to which the Laws of Nature and of Nature's God entitle them,
  a decent respect to the opinions of mankind requires that they should
  declare the causes which impel them to the separation.
  ---And there are records of type "accessory" with the following properties:
  ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
  | id        | name           | code       | sorting | thumbnailImage | priceType  | priceValue  | accessoryCategoryId  | teaser    | minTotalWidth | maxTotalWidth | profileIds       |
  | "tshirts" | "tshirts-name" | "tshsirts" | 1       | "tshirts.jpg"  | "constant" | 100         | "2"                  | "tshirts" |               |               | ["p1","p2","p3"] |
  | "tshirtm" | "tshirtm-name" | "tshsirtm" | 2       |                | "constant" | 110         | "2"                  | "tshirtm" |               |               | ["p1","p2"]      |
  | "tshirtl" | "tshirtl-name" | "tshsirtl" | 3       | "tshirtl.jpg"  | "constant" | 120         | "2"                  | "tshirtl" |               |               | []               |
  ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
Scenario: Exceeding min/max value on the Roof-Width-Field, input [User Input], angle: [Angle]
  When I visit URL "/configurator/unterkonstruktion"
  And I select item "Individual" in the dropdown Preset-Field
  And I fill "[Angle]" into the Input of the Angle-Field
  And I fill "[User Input]" into the Input of the Roof-Depth-Field
  Then the Input in the Roof-Depth-Field should have text "[Actual Value]"
  And the Input in the Rafter-Length-Field should have text "[Rafter Length]"
  Where:
    -------------------------------------------------------
    | Angle | User Input | Actual Value   | Rafter Length |
    | 5     | 999        | 1000           | 1000          |
    | 5     | 7001       | 7000           | 7000          |
    | 25    | 999        | 1000           | 1097          |
    | 25    | 7000       | 6383           | 7000          |
    | 25    | 7001       | 6383           | 7000          |
    | 15    | 25000      | 6758           | 7000          |
    | 25    | 25000      | 6383           | 7000          |
    | 35    | 25000      | 5922           | 7000          |
    | 45    | 25000      | 5439           | 7000          |
    -------------------------------------------------------sucks
Cucumber issues
Cucumber issues
Scenario: Viewing blog posts
    Given there are 3 posts in the database
    When I visit the blog
    Then the title of the 1st post should be "Hello World"Cucumber issues
  When I expand the 2nd post
  Then the expanded post should contain a comments sectionCucumber issues
When I click on div p ul li:nth-child(2) aCucumber issues
Cucumber issues
Solutions
Solutions
Solutions
    Given there are Posts in the database:
        -------------------------------------
    	| title         | body  | authorId  |
        | "Hello World" | "..." | "alice"   |
        | "Lorem Ipsum" | "..." | "bob"     |
        | "Foo Bar Baz" | "..." | "charlie" |
        -------------------------------------
    Then the title of the 1st post should be "Hello World"    Given there are 3 posts in the database
    Then the title of the 1st post should be "Hello World"Before:
Then the 1st product should be selectedAfter:
Then ".product:nth-child(1)" should have HTML class "is-selected"
And I should see ".product:nth-child(1) .comments"Solutions
  Then the 4th post should contain a comments section  Then the expanded post should contain a comments sectionSolutions
Before:
When I click on div p ul li:nth-child(2) aAfter:
When I click on "[data-test-post]:nth-child(2) [data-test-title]"4. Use only semantic
data-test selectors
[data-test-main-menu] data-test-main-menu           main-menu           Main-Menu4. Use "Labels": a convenient DSL
for data-test selectors
When I click [data-test-post]:nth-child(2) [data-test-expand-button]4. Reverse the order
in compound selectors
When I click the Expand-Button in the 2nd PostBefore:
After:
<div class="container">
    <article data-test-post>
    </article>
</div>
    
    
<div class="container">
    <article data-test-post>
    </article>
    <article data-test-post>
    </article>
 </div>
    
    
<div class="container">
    <article data-test-post>
    </article>
    <article data-test-post>
    </article>
 </div>:nth-child() does not work as expected
2nd Post
[data-test-post]
:nth-child(2)
1
2
3
4
5
<div class="container">
    <article data-test-post>
    </article>
</div>
    
    
<div class="container">
    <article data-test-post>
    </article>
    <article data-test-post>
    </article>
 </div>
    
    
<div class="container">
    <article data-test-post>
    </article>
    <article data-test-post>
    </article>
 </div>Use :eq(2) instead of :nth-child(2)
2nd Post
[data-test-post]
:eq(2)
1
2
3
4
5
Solutions
5. Improving test output
Thank you!
» ^_^ «
Andrey Mikhaylov
lolma.us
github.com/lolmaus
simplabs.com
A secret slide 🤫