SlideShare a Scribd company logo
Building an
Automated CSS
Testing Workflow
Ankit Rastogi
Khyati Sehgal
Building an automated css testing workflow
Building an automated css testing workflow
Why
CSS
Testing
Declarative
Programming
Wikipedia
Write Only
Language
Wikipedia
Code Quality
Paralyzed Structural Quality
Building an automated css testing workflow
Building an automated css testing workflow
Refactoring
at scale
confidence
●
●
●
●
●
In a nutshell CSS is
●
●
●
●
●
In a nutshell CSS is
CSS needs Testing
Current development
workflow
Current CSS Development Workflow
Techniques
●
●
Syntax Checks
Syntax Checks
●
●
Style Guides & linting
Style Guides & linting
●
●
Image Diff
●
●
●
Image Diff
●
Comparing styles in DOM
Comparing styles in DOM
New development
workflow
New CSS Development Workflow
Real implementation learning
●
●
●
●
Real implementation learning
●
●
●
●
Ecosystem
Questions
&
Answers
@khyatisehgal89 @ankit0rastogi
Ad

Recommended

Joomla! Bug Squashing at JUG Sorø
Joomla! Bug Squashing at JUG Sorø
Gunjan Patel
 
Ivan Pashko ITEM 2018
Ivan Pashko ITEM 2018
ITEM
 
CSS-in-JS in React: Why, current state, and bright future.
CSS-in-JS in React: Why, current state, and bright future.
Andrii Los
 
QA on Drupal projects - Drupal Dev Days Seville 2017
QA on Drupal projects - Drupal Dev Days Seville 2017
La Drupalera
 
Docker, your best ally to migrate & upgrading your Drupal - Drupal Dev Days S...
Docker, your best ally to migrate & upgrading your Drupal - Drupal Dev Days S...
La Drupalera
 
TDD with Python and App Engine
TDD with Python and App Engine
Ricardo Bánffy
 
Style Validator at breakout session of TPAC2015
Style Validator at breakout session of TPAC2015
Takeharu Igari
 
Grammarly Meetup: DevOps at Grammarly: Scaling 100x
Grammarly Meetup: DevOps at Grammarly: Scaling 100x
Grammarly
 
QA on drupal projects
QA on drupal projects
La Drupalera
 
Responsive testing in Drupal - Drupal Developer Days
Responsive testing in Drupal - Drupal Developer Days
La Drupalera
 
Beyond the web: Mobile apps using Drupal & Ionic 2 - Drupal Dev Days Seville ...
Beyond the web: Mobile apps using Drupal & Ionic 2 - Drupal Dev Days Seville ...
La Drupalera
 
Why no one is looking for rockstar programmers (updated version)
Why no one is looking for rockstar programmers (updated version)
Wiktor Schmidt
 
Reactive extensions (rx js) in dnn
Reactive extensions (rx js) in dnn
jsheely83
 
(Open Hack Night Fall 2014) Overview
(Open Hack Night Fall 2014) Overview
James Griffin
 
Lab view
Lab view
Saran Kumar
 
QA 4 python
QA 4 python
BeDjango
 
Behavior-Driven Design: One Team's Exploration
Behavior-Driven Design: One Team's Exploration
dtcoutu
 
Java Tutorial course
Java Tutorial course
Khyati Sehgal
 
Core java concepts
Core java concepts
Ram132
 
Java programming course for beginners
Java programming course for beginners
Eduonix Learning Solutions
 
Introduction to Java Programming Language
Introduction to Java Programming Language
jaimefrozr
 
Introduction to Java Programming
Introduction to Java Programming
Ravi Kant Sahu
 
Core java slides
Core java slides
Abhilash Nair
 
Introduction to java
Introduction to java
Veerabadra Badra
 
Java tutorial PPT
Java tutorial PPT
Intelligo Technologies
 
"Database isolation: how we deal with hundreds of direct connections to the d...
"Database isolation: how we deal with hundreds of direct connections to the d...
Fwdays
 
The Future of Technology: 2025-2125 by Saikat Basu.pdf
The Future of Technology: 2025-2125 by Saikat Basu.pdf
Saikat Basu
 
Coordinated Disclosure for ML - What's Different and What's the Same.pdf
Coordinated Disclosure for ML - What's Different and What's the Same.pdf
Priyanka Aash
 
PyCon SG 25 - Firecracker Made Easy with Python.pdf
PyCon SG 25 - Firecracker Made Easy with Python.pdf
Muhammad Yuga Nugraha
 
OWASP Barcelona 2025 Threat Model Library
OWASP Barcelona 2025 Threat Model Library
PetraVukmirovic
 

More Related Content

What's hot (9)

QA on drupal projects
QA on drupal projects
La Drupalera
 
Responsive testing in Drupal - Drupal Developer Days
Responsive testing in Drupal - Drupal Developer Days
La Drupalera
 
Beyond the web: Mobile apps using Drupal & Ionic 2 - Drupal Dev Days Seville ...
Beyond the web: Mobile apps using Drupal & Ionic 2 - Drupal Dev Days Seville ...
La Drupalera
 
Why no one is looking for rockstar programmers (updated version)
Why no one is looking for rockstar programmers (updated version)
Wiktor Schmidt
 
Reactive extensions (rx js) in dnn
Reactive extensions (rx js) in dnn
jsheely83
 
(Open Hack Night Fall 2014) Overview
(Open Hack Night Fall 2014) Overview
James Griffin
 
Lab view
Lab view
Saran Kumar
 
QA 4 python
QA 4 python
BeDjango
 
Behavior-Driven Design: One Team's Exploration
Behavior-Driven Design: One Team's Exploration
dtcoutu
 
QA on drupal projects
QA on drupal projects
La Drupalera
 
Responsive testing in Drupal - Drupal Developer Days
Responsive testing in Drupal - Drupal Developer Days
La Drupalera
 
Beyond the web: Mobile apps using Drupal & Ionic 2 - Drupal Dev Days Seville ...
Beyond the web: Mobile apps using Drupal & Ionic 2 - Drupal Dev Days Seville ...
La Drupalera
 
Why no one is looking for rockstar programmers (updated version)
Why no one is looking for rockstar programmers (updated version)
Wiktor Schmidt
 
Reactive extensions (rx js) in dnn
Reactive extensions (rx js) in dnn
jsheely83
 
(Open Hack Night Fall 2014) Overview
(Open Hack Night Fall 2014) Overview
James Griffin
 
QA 4 python
QA 4 python
BeDjango
 
Behavior-Driven Design: One Team's Exploration
Behavior-Driven Design: One Team's Exploration
dtcoutu
 

Viewers also liked (8)

Java Tutorial course
Java Tutorial course
Khyati Sehgal
 
Core java concepts
Core java concepts
Ram132
 
Java programming course for beginners
Java programming course for beginners
Eduonix Learning Solutions
 
Introduction to Java Programming Language
Introduction to Java Programming Language
jaimefrozr
 
Introduction to Java Programming
Introduction to Java Programming
Ravi Kant Sahu
 
Core java slides
Core java slides
Abhilash Nair
 
Introduction to java
Introduction to java
Veerabadra Badra
 
Java tutorial PPT
Java tutorial PPT
Intelligo Technologies
 
Java Tutorial course
Java Tutorial course
Khyati Sehgal
 
Core java concepts
Core java concepts
Ram132
 
Introduction to Java Programming Language
Introduction to Java Programming Language
jaimefrozr
 
Introduction to Java Programming
Introduction to Java Programming
Ravi Kant Sahu
 
Ad

Recently uploaded (20)

"Database isolation: how we deal with hundreds of direct connections to the d...
"Database isolation: how we deal with hundreds of direct connections to the d...
Fwdays
 
The Future of Technology: 2025-2125 by Saikat Basu.pdf
The Future of Technology: 2025-2125 by Saikat Basu.pdf
Saikat Basu
 
Coordinated Disclosure for ML - What's Different and What's the Same.pdf
Coordinated Disclosure for ML - What's Different and What's the Same.pdf
Priyanka Aash
 
PyCon SG 25 - Firecracker Made Easy with Python.pdf
PyCon SG 25 - Firecracker Made Easy with Python.pdf
Muhammad Yuga Nugraha
 
OWASP Barcelona 2025 Threat Model Library
OWASP Barcelona 2025 Threat Model Library
PetraVukmirovic
 
Daily Lesson Log MATATAG ICT TEchnology 8
Daily Lesson Log MATATAG ICT TEchnology 8
LOIDAALMAZAN3
 
cnc-processing-centers-centateq-p-110-en.pdf
cnc-processing-centers-centateq-p-110-en.pdf
AmirStern2
 
9-1-1 Addressing: End-to-End Automation Using FME
9-1-1 Addressing: End-to-End Automation Using FME
Safe Software
 
Quantum AI Discoveries: Fractal Patterns Consciousness and Cyclical Universes
Quantum AI Discoveries: Fractal Patterns Consciousness and Cyclical Universes
Saikat Basu
 
2025_06_18 - OpenMetadata Community Meeting.pdf
2025_06_18 - OpenMetadata Community Meeting.pdf
OpenMetadata
 
Curietech AI in action - Accelerate MuleSoft development
Curietech AI in action - Accelerate MuleSoft development
shyamraj55
 
Smarter Aviation Data Management: Lessons from Swedavia Airports and Sweco
Smarter Aviation Data Management: Lessons from Swedavia Airports and Sweco
Safe Software
 
AI VIDEO MAGAZINE - June 2025 - r/aivideo
AI VIDEO MAGAZINE - June 2025 - r/aivideo
1pcity Studios, Inc
 
Salesforce Summer '25 Release Frenchgathering.pptx.pdf
Salesforce Summer '25 Release Frenchgathering.pptx.pdf
yosra Saidani
 
Using the SQLExecutor for Data Quality Management: aka One man's love for the...
Using the SQLExecutor for Data Quality Management: aka One man's love for the...
Safe Software
 
Oh, the Possibilities - Balancing Innovation and Risk with Generative AI.pdf
Oh, the Possibilities - Balancing Innovation and Risk with Generative AI.pdf
Priyanka Aash
 
Python Conference Singapore - 19 Jun 2025
Python Conference Singapore - 19 Jun 2025
ninefyi
 
Securing AI - There Is No Try, Only Do!.pdf
Securing AI - There Is No Try, Only Do!.pdf
Priyanka Aash
 
10 Key Challenges for AI within the EU Data Protection Framework.pdf
10 Key Challenges for AI within the EU Data Protection Framework.pdf
Priyanka Aash
 
The Future of Product Management in AI ERA.pdf
The Future of Product Management in AI ERA.pdf
Alyona Owens
 
"Database isolation: how we deal with hundreds of direct connections to the d...
"Database isolation: how we deal with hundreds of direct connections to the d...
Fwdays
 
The Future of Technology: 2025-2125 by Saikat Basu.pdf
The Future of Technology: 2025-2125 by Saikat Basu.pdf
Saikat Basu
 
Coordinated Disclosure for ML - What's Different and What's the Same.pdf
Coordinated Disclosure for ML - What's Different and What's the Same.pdf
Priyanka Aash
 
PyCon SG 25 - Firecracker Made Easy with Python.pdf
PyCon SG 25 - Firecracker Made Easy with Python.pdf
Muhammad Yuga Nugraha
 
OWASP Barcelona 2025 Threat Model Library
OWASP Barcelona 2025 Threat Model Library
PetraVukmirovic
 
Daily Lesson Log MATATAG ICT TEchnology 8
Daily Lesson Log MATATAG ICT TEchnology 8
LOIDAALMAZAN3
 
cnc-processing-centers-centateq-p-110-en.pdf
cnc-processing-centers-centateq-p-110-en.pdf
AmirStern2
 
9-1-1 Addressing: End-to-End Automation Using FME
9-1-1 Addressing: End-to-End Automation Using FME
Safe Software
 
Quantum AI Discoveries: Fractal Patterns Consciousness and Cyclical Universes
Quantum AI Discoveries: Fractal Patterns Consciousness and Cyclical Universes
Saikat Basu
 
2025_06_18 - OpenMetadata Community Meeting.pdf
2025_06_18 - OpenMetadata Community Meeting.pdf
OpenMetadata
 
Curietech AI in action - Accelerate MuleSoft development
Curietech AI in action - Accelerate MuleSoft development
shyamraj55
 
Smarter Aviation Data Management: Lessons from Swedavia Airports and Sweco
Smarter Aviation Data Management: Lessons from Swedavia Airports and Sweco
Safe Software
 
AI VIDEO MAGAZINE - June 2025 - r/aivideo
AI VIDEO MAGAZINE - June 2025 - r/aivideo
1pcity Studios, Inc
 
Salesforce Summer '25 Release Frenchgathering.pptx.pdf
Salesforce Summer '25 Release Frenchgathering.pptx.pdf
yosra Saidani
 
Using the SQLExecutor for Data Quality Management: aka One man's love for the...
Using the SQLExecutor for Data Quality Management: aka One man's love for the...
Safe Software
 
Oh, the Possibilities - Balancing Innovation and Risk with Generative AI.pdf
Oh, the Possibilities - Balancing Innovation and Risk with Generative AI.pdf
Priyanka Aash
 
Python Conference Singapore - 19 Jun 2025
Python Conference Singapore - 19 Jun 2025
ninefyi
 
Securing AI - There Is No Try, Only Do!.pdf
Securing AI - There Is No Try, Only Do!.pdf
Priyanka Aash
 
10 Key Challenges for AI within the EU Data Protection Framework.pdf
10 Key Challenges for AI within the EU Data Protection Framework.pdf
Priyanka Aash
 
The Future of Product Management in AI ERA.pdf
The Future of Product Management in AI ERA.pdf
Alyona Owens
 
Ad