CHAPTERS
OVERVIEW
Date pickers are one essential UI for many websites where we pick data by writing or selecting. And if it does not function well, data can get fumbled; you don't want problems like someoneâs birth year registered on your website being 2024 while 2022 is ongoing, right? Automating date pickers can be tricky however, Playwright frameworks provide various methods to automate date pickers for web automation easily.
Playwright is an automation tool for an end to end testing of websites on browsers such as Chromium, Firefox, and WebKit. Playwright automation framework is gaining more and more popularity in the testing domain. One survey by the State of JS shows that Playwrightâs awareness has gone up to 34% in a mere span of 2 years since it was made live by Microsoft in 2020. It is because Playwright is faster than Selenium or other frameworks, Supports various languages such as JavaScript, Python, and .NET, makes it more favorable to developers, and is deployed by Microsoft, which gives unshaken credibility.
In this Playwright tutorial, you will learn two different methods for automating date pickers or calendars using the Playwright automation framework and with the help of LambdaTestâs Selenium Playground.
So, letâs get started!
fill() command in Playwright is used to fill the field with some test data. It is used for inputting values in inboxes, text areas, and other elements of web pages. You can add a locator of an element, and it will prompt an input event with given test data.
LambdaTest Selenium playground provides a date picker demo, there are two types of calendars; both have a âDD-MM-YYYYâ date format. The first one is with ups and down arrows, and the one is with left and right arrows. Both are the same; basically, just the UI is different.
Automating date pickers with the fill() command is an easier and short method. All you have to do is pass the date with the fill() function. Here are the steps for this method.
Test scenario:
Hereâs the test script for automating the date picker with the fill() command.
import { test } from "@Playwright/test";
test("Calendar demo using fill function", async ({ page }) => {
await page.goto("https://www.lambdatest.com/selenium-playground/bootstrap-date-picker-demo");
let date = "1994-12-04"
await page.fill("id=birthday", date);
await page.waitForTimeout(3000)
})
Here are step-by-step explanations of how it has been done.
Step 1: Pass the import statement to the import Playwright. Create a test block and add the URL of the page.
Step 2: Pass the test data with the help of the âletâ function. Keep the data type as a âdateâ.
test("Calendar demo using fill function", async ({ page }) => {
await page.goto("https://www.lambdatest.com/selenium-playground/bootstrap-date-picker-demo");
let date = "1994-12-04"
Step 3: Now, to add that data to an inbox, use the fill() command to pass our test id and test data.
await page.fill("id=birthday", date);
await page.waitForTimeout(3000)
})
Note: You can get a failure while testing because date formation is not similar to the expected format.
To search the expected format for the date in a webpage, go to the console log and type this:
Document.getElementById("birthday").value
It will give you value that is present in a particular ID.
In this example, our date formation is set as âYYYY-MM-DD.â So use the same formation while adding test data.
Run the test, and you can use waitForTimeout to see the execution slowly.
Moment.js is an open and free JavaScript tool that helps to tackle issues with date and time. It is a package of native JavaScript date objects which helps to manipulate or display date/time in JavaScript easily.
The fill method is easier, where we just inserted data in the inbox, and we got results. However, to create a perfect test case for date pickers, there is another method where we will use the previous and next buttons to select months and years and perform a clicking action on a date. Here we will understand, step by step, how to pick dates from the current month, the previous month, and the next month.
Test scenario:
Test script for automating date pickers with the moment method:
async function selectDate(date: number, dateToSelect: string) {
await page.click("//input[@placeholder='Start date']")
const mmYY = page.locator("(//table[@class='table-condensed']//th[@class='datepicker-switch'])[1]");
const prev = page.locator("(//table[@class='table-condensed']//th[@class='prev'])[1]");
const next = page.locator("(//table[@class='table-condensed']//th[@class='next'])[1]");
await prev.click();
await page.click("//td[@class='date'][text()='4']")
Here are the steps for performing the test for the current month:
Step 1: Define the URL with the help of the goto command.
Step 2: Now, for picking the date, you need first to perform a click action on the inbox. Find its element from inspect and perform a click action to open the calendar.
await page.click("//input[@placeholder='Start date']")
Step 3: When the calendar opens, select the month. For that, first, grab elements for the âprevious button,â ânext button,â and âdate picker switchâ.
Elements for date picker switch:
Inspect the date picker switch because there are five different date picker buttons. You have to write a collection-based XPath of it, which will pick an element for the specific switch you are testing on.
const mmYY = page.locator("(//table[@class='table-condensed']//th[@class='datepicker-switch'])[1]")
Here in the locator, first define the elements table where the button is and then define the button.
Elements for previous/next buttons:
Elements for the previous and next buttons are in the same table; simply make changes in class for the previous and next buttons.
const prev = page.locator("(//table[@class='table-condensed']//th[@class='prev'])[1]");
const next = page.locator("(//table[@class='table-condensed']//th[@class='next'])[1]");
Step 4: Now, for example, you want to select the 4th date of the previous month. For that, you have to perform the click action on the previous button and then click for the date 4th.
await prev.click();
await page.click("//td[@class='date'][text()='4']")
Note: While finding XPath for a date, there is a text â4â for every month, but their âclassâ will be different, for a current month it will be âday,â and for next month it will be ânew day.â We are focusing on the current month so that it will be âdayâ.
This one was a basic idea of this test, to check it ran the test.
Run Automated Playwright Tests Online. Try LambdaTest Now!
In the previous example, you picked dates from the current month. Now let's move ahead and write a test script for picking a date from another month.
Test scenario:
You can continue with the same test because the defined elements for buttons are the same.
async function selectDate(date: number, dateToSelect: string) {
await page.click("//input[@placeholder='Start date']")
const mmYY = page.locator("(//table[@class='table-condensed']//th[@class='datepicker-switch'])[1]");
const prev = page.locator("(//table[@class='table-condensed']//th[@class='prev'])[1]");
const next = page.locator("(//table[@class='table-condensed']//th[@class='next'])[1]");
let dateToSelect: string = "May 2019"
while (await mmYY.textContent() != dateToSelect) {
await prev.click();
await prev.click();
await page.click("//td[@class='date'][text()='4']").
Here are additional changes needed for this test.
let dateToSelect: string = "May 2019"
while (await mmYY.textContent() != dateToSelect) {
await prev.click();
Here is the explanation:
With date pickers, locating UI elements can be challenging due to dynamic attributes and varying structures.
Playwrightâs robust locators and loops simplify handling such elements, ensuring accurate interactions. Follow the video below to learn how to handle UI elements in Playwright.
After writing the test case for the previous month, you have to make certain additional changes to make this test script eligible for testing on next month's date or on any date. Also, you will need to call the moment.js library to execute tests on date pickers for different months or years.
Test scenario:
Here is the modified test script required to perform this test.
async function selectDate(date: number, dateToSelect: string) {
await page.click("//input[@placeholder='Start date']")
const mmYY = page.locator("(//table[@class='table-condensed']//th[@class='datepicker-switch'])[1]");
const prev = page.locator("(//table[@class='table-condensed']//th[@class='prev'])[1]");
const next = page.locator("(//table[@class='table-condensed']//th[@class='next'])[1]");
// let dateToSelect: string = "May 2019";
const thisMonth = moment(dateToSelect, "MMMM YYYY").isBefore();
console.log("this month? " + thisMonth);
while (await mmYY.textContent() != dateToSelect) {
if (thisMonth) {
await prev.click();
} else {
await next.click();
}
}
Let's continue with a similar test case and add some steps:
import { test } from "@Playwright/test";
import moment from "moment";
const thisMonth = moment(dateToSelect, "MMMM YYYY").isBefore();
console.log("this month? " + thisMonth);
while (await mmYY.textContent() != dateToSelect) {
if (thisMonth) {
await prev.click();
} else {
await next.click();
}
}
await page.click("//td[@class='day'][text()='4']");
}
Here, with the help of the previous script, you can select any year, month, or date, but it's not organized. Month and year at another place while the date is at another command line. Create one new function which is organized and reusable. Here are the following steps:
async function selectDate(date: number, dateToSelect: string) {
await page.click("//input[@placeholder='Start date']")
const mmYY = page.locator("(//table[@class='table-condensed']//th[@class='datepicker-switch'])[1]");
const prev = page.locator("(//table[@class='table-condensed']//th[@class='prev'])[1]");
const next = page.locator("(//table[@class='table-condensed']//th[@class='next'])[1]");
// let dateToSelect: string = "May 2019";
const thisMonth = moment(dateToSelect, "MMMM YYYY").isBefore();
console.log("this month? " + thisMonth);
while (await mmYY.textContent() != dateToSelect) {
if (thisMonth) {
await prev.click();
} else {
await next.click();
}
}
await page.click("//td[@class='day'][text()='${date}']");
}
})
Note: Changes you have to make to connect the new function with the script are highlighted in the green block.
Step 1: Select the whole script; once you select it, you will find the bulb icon from where you can create a new function. Give it the name âSelectDateâ.
Step 2: This ânew functionâ will sync with the selected script.
Step 3: Before making changes for month and year, comment on the previous code line for month and year.
// let dateToSelect: string = "May 2019";
Step 4: Add the dateToSelect string in a new function. So when you can add the value of month and year in a new function, It will put the value in the âwhileâ loop, and the rest of the process will be the same as the previous test.
async function selectDate(date: number, dateToSelect: string)
Step 5: Code line where you have defined the element for a date, make changes, and add âdateâ with $ sign to connect with the âselectDateâ function.
await page.click("//td[@class='day'][text()='${date}']");
Finally, you are ready to launch your new test script to automate date pickers.
LambdaTest is a continuous quality cloud testing platform with an automation testing grid of 3000+ browsers and operating systems that help you scale your Playwright test execution effortlessly. With LambdaTest, you can.
You can execute the Playwright test on the LambdaTest platform with desired capabilities such as browser name, version, OS, etc., and some advanced capabilities such as command logs and network logs, etc. Here is the config.ts file for executing the Playwright test on the LambdaTest platform.
You can access all those tests from the Playwright tutorial from this GitHub repo.
So thatâs it, folks! After compiling this tutorial, I hope you get a good insight into automating date pickers and calendars. Also, you learned about the moment library and how to use it to simplify automation in Playwright. We will continue our learning in the next tutorial.
The Playwright automation framework is fast, reliable, and easy compared to other frameworks and supports all major browsers. That's why its popularity propelled over time. To learn Playwright automation testing, follow the LambdaTest YouTube channel.
It is easy to understand Playwright automation, as you only require basic knowledge of JavaScript and TypeScript. You can leverage your testing career with our globally recognized certification. LambdaTest provides free Playwright 101 certification to help you elevate your automation testing skills.
API calls in Playwright are flexible: they are made outside of the browser runtime but can optionally share the cookie state of the browser runtime. This means that you can create both standalone API tests in Playwright, as well as make API calls intermingled with UI actions like clicks and inputs.
MomentJS is a JavaScript package that makes it very simple to parse, validate, manipulate, and display dates and times in JavaScript.
Did you find this page helpful?