atournayre/fixtures-bundle

There is no license information available for the latest version (0.2.0) of this package.

Fixtures bundle

Installs: 63

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 1

Forks: 0

Open Issues: 0

Type:symfony-bundle

0.2.0 2024-03-03 10:32 UTC

This package is auto-updated.

Last update: 2024-05-03 10:51:06 UTC


README

This bundle helps creating fixtures (with Alice).

Requirements

Symfony 6.2.*

PHP >=8.2

Install

Use Composer to install the package:

Composer

composer require atournayre/fixtures-bundle --dev

Register bundle

// config/bundles.php

return [
    // ...
    Hautelook\AliceBundle\HautelookAliceBundle::class => ['dev' => true, 'test' => true],
    Atournayre\Bundle\FixtureBundle\AtournayreFixtureBundle::class => ['dev' => true, 'test' => true],
    // ...
]

Features

Command to load fixtures:

php bin/console fixtures

Events:

  • BeforeFixturesEvent
  • AfterFixturesEvent

Providers:

  • DateTime
  • Entity
  • Uuid
  • Hash password

Examples

Fixtures

App\Entity\User:
  admin:
    # id: '<uuidV1()>'
    id: '<uuidV4()>'
    # id: '<uuidV6()>'
    # id: '<uuidV7()>'
    # id: '<uuidV8(uuid)>'
    email: 'admin@example.com'
    password: '<hashPassword(super_password)>'
    # The current date with specific time
    dateTime: '<currentDateWithTime(09:10)>'
    # The current date with random hour
    otherDateTime: '<randomHourWithDate()>'
    # A related entity identified by its id
    relatedEntity: '<entity<1, App\Entity\RelatedEntity)>'
    # A related entity identified by its uuid
    otherRelatedEntity: '<entity<b8ecc665-0d81-4a09-8ede-2c23a4355836, App\Entity\RelatedEntity)>'

Events

Documentation : https://symfony.com/doc/current/event_dispatcher.html#defining-event-listeners-with-php-attributes

<?php
namespace App\Listener;

use Symfony\Component\EventDispatcher\Attribute\AsEventListener;
use Atournayre\Bundle\FixtureBundle\Event\AfterFixturesEvent;

#[AsEventListener]
readonly class AfterFixtureListener
{
    public function __invoke(AfterFixturesEvent $event): void
    {
        // Your code    
    }
}

Contribute

Contributions to the package are always welcome!

License

All contents of this package are licensed under the MIT license.