Skip to content

Latest commit

 

History

History
90 lines (72 loc) · 3.61 KB

README.md

File metadata and controls

90 lines (72 loc) · 3.61 KB

Angular testing pyramid

Main page (quotes list) Quote page
main page quote_page

Actions:

  1. The quotes list display
  2. Open/close the "add quote" form
  3. Create new quote (+ form validation)
  4. Open the quote page
  5. Back to the main page

Tests (e2e / integration / contract / unit)

E2E:

  1. A list of quotes should be displayed on the page
  2. The created quote should be appended to list
  3. Quote page should be opened on click to quote item

Integration:

  1. Displayed text of quote is correct
  2. Displayed author of quote is correct
  3. Page should be changed to main on click to "To quotes list"
  1. Title of page contains correct text
  2. Quotes list is displayed and count of displayed quotes matches the input data
  3. Quote create form is opened by default
  4. Form is closing when "X" button is clicked
  5. Form is opening when "Create quote" button is clicked
  1. Count of displayed quotes matches the input data
  2. Text of first quote is correct
  3. Author of first quote is correct
  4. First quote item have link to its page
  1. Text of error validation is not displayed by default
  2. Validation error is displayed, when:
    1. Author name length less than 2 characters
    2. Text less than 2 characters
    3. Author name length greater than 64 characters
    4. Text length greater than 256 characters
    5. Author is not filled 6.Text is not filled
  3. Validation error is not displayed, when:
    1. length of author name > 2 & < 64 and length of text > 2 & < 256
  4. Form submitting
    1. When form is valid
      1. The entered data is sent
      2. Fields of form cleans
    2. When form is not valid
      1. The entered data is not sent

Contract:

  1. loadQuotesList() - requests a list of quotes
  2. loadQuote() - requests quote by id
  3. createQuote() - quote creating

Unit:

  1. When QuotesFetchAll is triggered, a list of quotes is requested and the QuotesFetchedAll event is created
  2. When QuotesFetchOne is triggered, a quote is requested and the QuotesFetchedOne event is created
  3. When QuotesCreate is triggered, the quote is sent to the server and the QuotesFetchedOne event is created
  1. QuotesFetchedAll must replace quotes list in store
  2. QuotesFetchedOne must append quote to the list in store
  3. QuotesFetchedOne must do not append quote to the list in store, if quote is exist in list
  4. QuotesFetchedOne must append quote to the list in store, if quote is not exist in list
  1. Creates QuotesFetchOne action, for loading data from server
  2. Gives quote from store by id from router
  3. If the store does not have the expected quote, then it expects its appearance (filter)
  1. Creates QuotesFetchAll action, for loading data from server
  2. Gives Observable with quotes list from store
  3. Observable with a list of quotes can send new data