Weave Code
Code Weaver
Helps Laravel developers discover, compare, and choose open-source packages. See popularity, security, maintainers, and scores at a glance to make better decisions.
Feedback
Share your thoughts, report bugs, or suggest improvements.
Subject
Message
Behat Page Object Extension

Behat Page Object Extension Laravel Package

sensiolabs/behat-page-object-extension

Behat extension that helps you apply the Page Object pattern in browser acceptance tests. Provides page and element objects, reusable actions and assertions, and integrates with Mink to keep step definitions clean and maintainable.

View on GitHub
Deep Wiki
Context7

Page object extension for Behat

Frequently asked questions about Behat Page Object Extension
How do I install this extension for Laravel Behat tests?
Run `composer require --dev sensiolabs/behat-page-object-extension` and configure it in `behat.yml` under the `extensions` key. Ensure Behat and Mink (or Behat-MinkExtension) are also installed. Laravel’s autoloader will handle Page Object classes if placed in `src/Tests/PageObjects/` or a PSR-4 compatible path.
Does this work with Laravel 10 and the latest Behat?
Yes, the extension supports Laravel 8/9/10 via Symfony 5+ compatibility. Use Behat 3.9+ and Mink 1.8+ for full functionality. Test with `behat --version` to confirm compatibility before integrating.
Can I use this for API testing instead of UI?
While primarily designed for UI automation, you can adapt it for API testing by combining it with Mink’s Goutte driver (for HTTP interactions) or custom contexts. However, Laravel Dusk or PestPHP may be more straightforward for API-focused workflows.
How do I inject Laravel services (e.g., Auth) into Behat contexts?
Use Behat’s `services.yml` to bind Laravel services like `@auth` or `@cache` to your context classes. Alternatively, bootstrap Laravel in a `FeatureContext` via `require __DIR__.'/../../../../bootstrap/app.php'` and access services through the container.
Will this slow down my CI/CD pipeline?
Yes, browser-based tests (e.g., Selenium) add overhead. Mitigate this by using Goutte for lightweight tests, running parallel test suites with Paratest, or optimizing Dockerized environments with pre-warmed browsers.
Is there a way to avoid flaky tests with this extension?
Flakiness often stems from dynamic UI elements. Use explicit waits in Page Objects (e.g., `waitForElement()`), retry logic in Mink, and avoid direct DOM assertions. Selenium’s headless mode can also reduce variability.
Can I use this with Laravel Dusk instead of Behat?
No, this extension is Behat-specific. Laravel Dusk has its own Page Object-like patterns (e.g., `Browser::visit()`), but lacks the structured Page Object pattern enforcement this extension provides. Choose based on your team’s BDD vs. testing-first workflow preference.
How do I structure Page Object classes for large Laravel apps?
Organize classes by feature (e.g., `src/Tests/PageObjects/Auth/LoginPage.php`) and use Laravel’s autoloader. For shared elements (e.g., headers), create base classes. Avoid deep nesting; keep Page Objects focused on single UI components or workflows.
Does this extension support parallel test execution?
Yes, but requires configuration. Use Mink’s Selenium with a grid (e.g., Sauce Labs or Selenium Hub) and Behat’s `--tags` or `--group` flags to split tests. Alternatively, leverage Paratest for PHP-level parallelism with Goutte.
What’s the best way to mock Laravel services in Behat tests?
Override Laravel’s service bindings in `services.yml` or use Behat’s `BeforeScenario` hooks to replace dependencies with mocks. For Auth, inject a fake guard or use `Auth::shouldReceive()` in contexts. Avoid real database interactions unless testing E2E flows.
Weaver

How can I help you explore Laravel packages today?

Conversation history is not saved when not logged in.
Prompt
Add packages to context
No packages found.
nasirkhan/laravel-sharekit
directorytree/privacy-filter-classifier
directorytree/privacy-filter
datacore/hub-sdk
develia/commons
cuci/prototurk-sdk
cuci/prototurk-sdk-symfony
develia/geo-bundle
dreamzy/livewire-charts
touchestate-sdk/php-sdk
22h/doctrine-garbage-collection-bundle
agtp/agtp-php
agtp/mod-php
splash/sonata-admin
splash/metadata
splash/openapi
splash/scopes
splash/toolkit
testo/output-teamcity
testo/bridge-symfony