feat: add routes, lang, tests, stubs, docs, and docker configurations

This commit is contained in:
2026-05-21 16:05:16 +07:00
parent fad70d096b
commit 28a06315b8
3385 changed files with 177070 additions and 0 deletions
@@ -0,0 +1,65 @@
<?php
use App\Helpers\PasswordRuleHelper;
use Illuminate\Support\Facades\Validator;
test('rules array includes required, string, min:12', function () {
$rules = PasswordRuleHelper::rules();
expect($rules)->toContain('required');
expect($rules)->toContain('string');
expect($rules)->toContain('min:12');
});
test('rules array includes regex for each charset class', function () {
$rules = PasswordRuleHelper::rules();
expect(implode('|', $rules))
->toContain('regex:/[a-z]/')
->toContain('regex:/[A-Z]/')
->toContain('regex:/[0-9]/');
});
test('messages contain min and regex keys', function () {
$msgs = PasswordRuleHelper::messages();
expect($msgs)->toHaveKeys(['password.min', 'password.regex']);
});
test('rules accept a strong password via Validator', function () {
$v = Validator::make(
['password' => 'Str0ng!Passw0rd2026'],
['password' => PasswordRuleHelper::rules()],
PasswordRuleHelper::messages(),
);
expect($v->fails())->toBeFalse();
});
test('rules reject short passwords', function () {
$v = Validator::make(
['password' => 'Abc123!'],
['password' => PasswordRuleHelper::rules()],
);
expect($v->fails())->toBeTrue();
});
test('rules reject passwords missing uppercase', function () {
$v = Validator::make(
['password' => 'all_lower_123!'],
['password' => PasswordRuleHelper::rules()],
);
expect($v->fails())->toBeTrue();
});
test('rules reject passwords missing digit', function () {
$v = Validator::make(
['password' => 'NoDigitsHere!'],
['password' => PasswordRuleHelper::rules()],
);
expect($v->fails())->toBeTrue();
});
test('rules reject passwords missing symbol', function () {
$v = Validator::make(
['password' => 'NoSymbolsHere1'],
['password' => PasswordRuleHelper::rules()],
);
expect($v->fails())->toBeTrue();
});