jeslxdev / dto-mocker
Gerador de mocks genéricos para DTOs/Inputs/Outputs em PHP, inspirado no Faker.
Installs: 0
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/jeslxdev/dto-mocker
Requires
- php: >=8.0
- symfony/console: ^6.0
Requires (Dev)
- phpunit/phpunit: ^9.5
This package is auto-updated.
Last update: 2026-01-03 20:59:40 UTC
README
Gerador leve de mocks para classes DTO/Inputs/Outputs em PHP. Gera instâncias e arquivos de fixtures para uso em testes e desenvolvimento.
Compatível com qualquer framework PHP (Laravel, Hyperf, Symfony etc.).
Instalação (desenvolvimento)
Recomendo instalar como dependência de desenvolvimento:
composer require --dev jeslxdev/dto-mocker
Observação: este repositório já contém um script CLI mínimo para gerar fixtures sem dependências de framework.
Uso programático
Exemplo simples em código:
use DtoMocker\DtoMocker; $mocker = new DtoMocker(); $dto = $mocker->make(\App\Dto\UserDto::class); // $dto é uma instância populada com valores gerados var_dump($dto);
Você pode sobrescrever geradores por tipo, por exemplo:
$mocker->extend('string', fn() => 'valor_fixo');
CLI: gerar fixtures
Inclui um utilitário mínimo para varrer classes e gerar fixtures JSON em tests/_fixtures.
Executar via composer script:
composer dto-mocker:generate
Ou direto:
php bin/generate-mocks.php --path=src --out=tests/_fixtures --count=3
Opções suportadas:
--path(padrão:src) — diretório a ser escaneado;--out(padrão:tests/_fixtures) — pasta de saída;--count(padrão:3) — quantas instâncias por classe.
Novas opções:
--format(json|php) — formato de saída;jsonpor padrão;--include-non-dto— incluir classes sem sufixoDto(usa detecção por propriedades tipadas);--only— lista separada por vírgula de classes (ou short names) a gerar, ex.:--only=UserDto,App\\Dto\\OrderDto;--max-depth— profundidade máxima de serialização/recursão (padrão: 3).
Detecção: por padrão o script inclui classes cujo nome termina com Dto. Use --include-non-dto para
fazer detecção por propriedades tipadas. Use --only para restringir a lista a classes específicas.
O que são fixtures
Fixtures são conjuntos de dados usados para inicializar o estado de testes ou ambientes de desenvolvimento. Este projeto gera fixtures em JSON ou PHP (arrays) que podem ser carregados em testes para simular entradas ou estados sem depender de banco de dados real.
Exemplos de saída
O script grava arquivos JSON com nome no formato Namespace_SubNamespace_ClassName.json.
Exemplo de uso em testes (PHPUnit): carregue o JSON gerado com json_decode() e use os dados como fixtures.
Integração com frameworks
Para integração com frameworks considere implementar um comando dedicado (Artisan/Hyperf) e templates de factories PHP; posso ajudar a adicionar essas integrações.
Testes
Rode a suíte com PHPUnit (ex.: em ambiente com PHP/Composer configurados):
composer install vendor/bin/phpunit -v
Contribuição
Pull requests são bem-vindos. Para mudanças maiores, abra uma issue primeiro.
PR checklist mínimo:
- testes atualizados e passando;
- seguir PSR-12;
- atualizar a documentação se necessário.