create-berna-stencil 2.0.9 → 2.0.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bin/create.js +2 -1
- package/package.json +1 -1
- package/src/backend/_core/vendor/composer/autoload_static.php +10 -10
- package/src/backend/_core/vendor/composer/installed.json +6 -6
- package/src/backend/_core/vendor/composer/installed.php +2 -2
- package/src/backend/_core/vendor/graham-campbell/result-type/.gitattributes +9 -0
- package/src/backend/_core/vendor/graham-campbell/result-type/.github/CODE_OF_CONDUCT.md +132 -0
- package/src/backend/_core/vendor/graham-campbell/result-type/.github/CONTRIBUTING.md +31 -0
- package/src/backend/_core/vendor/graham-campbell/result-type/.github/FUNDING.yml +2 -0
- package/src/backend/_core/vendor/graham-campbell/result-type/.github/SECURITY.md +14 -0
- package/src/backend/_core/vendor/graham-campbell/result-type/.github/workflows/stale.yml +11 -0
- package/src/backend/_core/vendor/graham-campbell/result-type/.github/workflows/tests.yml +40 -0
- package/src/backend/_core/vendor/graham-campbell/result-type/CHANGELOG.md +53 -0
- package/src/backend/_core/vendor/graham-campbell/result-type/LICENSE +21 -21
- package/src/backend/_core/vendor/graham-campbell/result-type/README.md +42 -0
- package/src/backend/_core/vendor/graham-campbell/result-type/composer.json +33 -33
- package/src/backend/_core/vendor/graham-campbell/result-type/phpunit.xml.dist +13 -0
- package/src/backend/_core/vendor/graham-campbell/result-type/src/Error.php +121 -121
- package/src/backend/_core/vendor/graham-campbell/result-type/src/Result.php +69 -69
- package/src/backend/_core/vendor/graham-campbell/result-type/src/Success.php +120 -120
- package/src/backend/_core/vendor/graham-campbell/result-type/tests/ResultTest.php +95 -0
- package/src/backend/_core/vendor/phpoption/phpoption/.gitattributes +13 -0
- package/src/backend/_core/vendor/phpoption/phpoption/.github/CODE_OF_CONDUCT.md +132 -0
- package/src/backend/_core/vendor/phpoption/phpoption/.github/CONTRIBUTING.md +30 -0
- package/src/backend/_core/vendor/phpoption/phpoption/.github/FUNDING.yml +2 -0
- package/src/backend/_core/vendor/phpoption/phpoption/.github/SECURITY.md +14 -0
- package/src/backend/_core/vendor/phpoption/phpoption/.github/workflows/static.yml +40 -0
- package/src/backend/_core/vendor/phpoption/phpoption/.github/workflows/tests.yml +40 -0
- package/src/backend/_core/vendor/phpoption/phpoption/LICENSE +200 -200
- package/src/backend/_core/vendor/phpoption/phpoption/Makefile +17 -0
- package/src/backend/_core/vendor/phpoption/phpoption/README.md +201 -0
- package/src/backend/_core/vendor/phpoption/phpoption/composer.json +50 -50
- package/src/backend/_core/vendor/phpoption/phpoption/phpstan-baseline.neon +44 -0
- package/src/backend/_core/vendor/phpoption/phpoption/phpstan.neon.dist +7 -0
- package/src/backend/_core/vendor/phpoption/phpoption/phpunit.xml.dist +13 -0
- package/src/backend/_core/vendor/phpoption/phpoption/src/PhpOption/LazyOption.php +175 -175
- package/src/backend/_core/vendor/phpoption/phpoption/src/PhpOption/None.php +136 -136
- package/src/backend/_core/vendor/phpoption/phpoption/src/PhpOption/Option.php +434 -434
- package/src/backend/_core/vendor/phpoption/phpoption/src/PhpOption/Some.php +169 -169
- package/src/backend/_core/vendor/phpoption/phpoption/tests/PhpOption/Tests/EnsureTest.php +72 -0
- package/src/backend/_core/vendor/phpoption/phpoption/tests/PhpOption/Tests/LazyOptionTest.php +357 -0
- package/src/backend/_core/vendor/phpoption/phpoption/tests/PhpOption/Tests/NoneTest.php +153 -0
- package/src/backend/_core/vendor/phpoption/phpoption/tests/PhpOption/Tests/OptionTest.php +166 -0
- package/src/backend/_core/vendor/phpoption/phpoption/tests/PhpOption/Tests/SomeTest.php +194 -0
- package/src/backend/_core/vendor/phpoption/phpoption/tests/bootstrap.php +8 -0
- package/src/backend/_core/vendor/phpoption/phpoption/vendor-bin/phpstan/composer.json +8 -0
- package/src/backend/_core/vendor/symfony/polyfill-ctype/Ctype.php +232 -232
- package/src/backend/_core/vendor/symfony/polyfill-ctype/LICENSE +19 -19
- package/src/backend/_core/vendor/symfony/polyfill-ctype/README.md +12 -12
- package/src/backend/_core/vendor/symfony/polyfill-ctype/bootstrap.php +50 -50
- package/src/backend/_core/vendor/symfony/polyfill-ctype/bootstrap80.php +46 -46
- package/src/backend/_core/vendor/symfony/polyfill-ctype/composer.json +38 -38
- package/src/backend/_core/vendor/symfony/polyfill-mbstring/LICENSE +19 -19
- package/src/backend/_core/vendor/symfony/polyfill-mbstring/Mbstring.php +1077 -1077
- package/src/backend/_core/vendor/symfony/polyfill-mbstring/README.md +13 -13
- package/src/backend/_core/vendor/symfony/polyfill-mbstring/Resources/unidata/caseFolding.php +119 -119
- package/src/backend/_core/vendor/symfony/polyfill-mbstring/Resources/unidata/lowerCase.php +1397 -1397
- package/src/backend/_core/vendor/symfony/polyfill-mbstring/Resources/unidata/titleCaseRegexp.php +5 -5
- package/src/backend/_core/vendor/symfony/polyfill-mbstring/Resources/unidata/upperCase.php +1489 -1489
- package/src/backend/_core/vendor/symfony/polyfill-mbstring/bootstrap.php +171 -171
- package/src/backend/_core/vendor/symfony/polyfill-mbstring/bootstrap80.php +167 -167
- package/src/backend/_core/vendor/symfony/polyfill-mbstring/composer.json +39 -39
- package/src/backend/_core/vendor/symfony/polyfill-php80/LICENSE +19 -19
- package/src/backend/_core/vendor/symfony/polyfill-php80/Php80.php +115 -115
- package/src/backend/_core/vendor/symfony/polyfill-php80/PhpToken.php +106 -106
- package/src/backend/_core/vendor/symfony/polyfill-php80/README.md +25 -25
- package/src/backend/_core/vendor/symfony/polyfill-php80/Resources/stubs/Attribute.php +31 -31
- package/src/backend/_core/vendor/symfony/polyfill-php80/Resources/stubs/PhpToken.php +16 -16
- package/src/backend/_core/vendor/symfony/polyfill-php80/Resources/stubs/Stringable.php +20 -20
- package/src/backend/_core/vendor/symfony/polyfill-php80/Resources/stubs/UnhandledMatchError.php +16 -16
- package/src/backend/_core/vendor/symfony/polyfill-php80/Resources/stubs/ValueError.php +16 -16
- package/src/backend/_core/vendor/symfony/polyfill-php80/bootstrap.php +42 -42
- package/src/backend/_core/vendor/symfony/polyfill-php80/composer.json +37 -37
- package/src/backend/_core/vendor/vlucas/phpdotenv/.editorconfig +15 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/.gitattributes +15 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/.github/CODE_OF_CONDUCT.md +132 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/.github/CONTRIBUTING.md +30 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/.github/FUNDING.yml +2 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/.github/SECURITY.md +14 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/.github/workflows/static.yml +40 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/.github/workflows/tests.yml +70 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/LICENSE +30 -30
- package/src/backend/_core/vendor/vlucas/phpdotenv/Makefile +17 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/README.md +370 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/UPGRADING.md +196 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/composer.json +60 -60
- package/src/backend/_core/vendor/vlucas/phpdotenv/phpstan-baseline.neon +157 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/phpstan.neon.dist +7 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/phpunit.xml.dist +13 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Dotenv.php +267 -267
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Exception/ExceptionInterface.php +12 -12
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Exception/InvalidEncodingException.php +12 -12
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Exception/InvalidFileException.php +12 -12
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Exception/InvalidPathException.php +12 -12
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Exception/ValidationException.php +12 -12
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Loader/Loader.php +48 -48
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Loader/LoaderInterface.php +20 -20
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Loader/Resolver.php +65 -65
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Parser/Entry.php +59 -59
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Parser/EntryParser.php +299 -299
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Parser/Lexer.php +58 -58
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Parser/Lines.php +127 -127
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Parser/Parser.php +53 -53
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Parser/ParserInterface.php +19 -19
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Parser/Value.php +88 -88
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Repository/Adapter/AdapterInterface.php +15 -15
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Repository/Adapter/ApacheAdapter.php +89 -89
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Repository/Adapter/ArrayAdapter.php +80 -80
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Repository/Adapter/EnvConstAdapter.php +88 -88
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Repository/Adapter/GuardedWriter.php +85 -85
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Repository/Adapter/ImmutableWriter.php +110 -110
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Repository/Adapter/MultiReader.php +48 -48
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Repository/Adapter/MultiWriter.php +64 -64
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Repository/Adapter/PutenvAdapter.php +91 -91
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Repository/Adapter/ReaderInterface.php +17 -17
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Repository/Adapter/ReplacingWriter.php +104 -104
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Repository/Adapter/ServerConstAdapter.php +88 -88
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Repository/Adapter/WriterInterface.php +27 -27
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Repository/AdapterRepository.php +107 -107
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Repository/RepositoryBuilder.php +272 -272
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Repository/RepositoryInterface.php +51 -51
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Store/File/Paths.php +44 -44
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Store/File/Reader.php +81 -81
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Store/FileStore.php +72 -72
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Store/StoreBuilder.php +141 -141
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Store/StoreInterface.php +17 -17
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Store/StringStore.php +37 -37
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Util/Regex.php +112 -112
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Util/Str.php +108 -108
- package/src/backend/_core/vendor/vlucas/phpdotenv/src/Validator.php +207 -207
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/Dotenv/DotenvTest.php +387 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/Dotenv/Loader/LoaderTest.php +86 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/Dotenv/Parser/EntryParserTest.php +234 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/Dotenv/Parser/LexerTest.php +40 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/Dotenv/Parser/LinesTest.php +53 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/Dotenv/Parser/ParserTest.php +98 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/Adapter/ArrayAdapterTest.php +57 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/Adapter/EnvConstAdapterTest.php +75 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/Adapter/PutenvAdapterTest.php +52 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/Adapter/ServerConstAdapterTest.php +75 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/RepositoryTest.php +305 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/Dotenv/Store/StoreTest.php +141 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/Dotenv/ValidatorTest.php +479 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/fixtures/env/.env +5 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/fixtures/env/assertions.env +18 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/fixtures/env/booleans.env +33 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/fixtures/env/commented.env +15 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/fixtures/env/empty.env +1 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/fixtures/env/example.env +1 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/fixtures/env/exported.env +7 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/fixtures/env/immutable.env +1 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/fixtures/env/integers.env +17 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/fixtures/env/large.env +2 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/fixtures/env/multibyte.env +3 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/fixtures/env/multiline.env +14 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/fixtures/env/multiple.env +4 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/fixtures/env/mutable.env +1 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/fixtures/env/nested.env +15 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/fixtures/env/quoted.env +11 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/fixtures/env/specialchars.env +8 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/fixtures/env/unicodevarnames.env +2 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/fixtures/env/utf8-with-bom-encoding.env +3 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/tests/fixtures/env/windows.env +1 -0
- package/src/backend/_core/vendor/vlucas/phpdotenv/vendor-bin/phpstan/composer.json +15 -0
- package/src/backend/config.php +19 -0
- package/src/frontend/data/site.json +43 -43
|
@@ -0,0 +1,305 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
|
|
3
|
+
declare(strict_types=1);
|
|
4
|
+
|
|
5
|
+
namespace Dotenv\Tests\Repository;
|
|
6
|
+
|
|
7
|
+
use Dotenv\Dotenv;
|
|
8
|
+
use Dotenv\Repository\Adapter\ArrayAdapter;
|
|
9
|
+
use Dotenv\Repository\RepositoryBuilder;
|
|
10
|
+
use Dotenv\Repository\RepositoryInterface;
|
|
11
|
+
use InvalidArgumentException;
|
|
12
|
+
use PHPUnit\Framework\TestCase;
|
|
13
|
+
use TypeError;
|
|
14
|
+
|
|
15
|
+
final class RepositoryTest extends TestCase
|
|
16
|
+
{
|
|
17
|
+
/**
|
|
18
|
+
* @var array<string, string>|null
|
|
19
|
+
*/
|
|
20
|
+
private $keyVal;
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* @before
|
|
24
|
+
*
|
|
25
|
+
* @return void
|
|
26
|
+
*/
|
|
27
|
+
public function refreshKeyVal()
|
|
28
|
+
{
|
|
29
|
+
$this->keyVal(true);
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
/**
|
|
33
|
+
* @return void
|
|
34
|
+
*/
|
|
35
|
+
private function load()
|
|
36
|
+
{
|
|
37
|
+
Dotenv::createMutable(\dirname(\dirname(__DIR__)).'/fixtures/env')->load();
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* Generates a new key/value pair or returns the previous one.
|
|
42
|
+
*
|
|
43
|
+
* Since most of our functionality revolves around setting/retrieving keys
|
|
44
|
+
* and values, we have this utility function to help generate new, unique
|
|
45
|
+
* key/value pairs.
|
|
46
|
+
*
|
|
47
|
+
* @param bool $reset
|
|
48
|
+
*
|
|
49
|
+
* @return array<string, string>
|
|
50
|
+
*/
|
|
51
|
+
private function keyVal(bool $reset = false)
|
|
52
|
+
{
|
|
53
|
+
if (!isset($this->keyVal) || $reset) {
|
|
54
|
+
$this->keyVal = [\uniqid() => \uniqid()];
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
return $this->keyVal;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
/**
|
|
61
|
+
* Returns the key from keyVal(), without reset.
|
|
62
|
+
*
|
|
63
|
+
* @return string
|
|
64
|
+
*/
|
|
65
|
+
private function key()
|
|
66
|
+
{
|
|
67
|
+
$keyVal = $this->keyVal();
|
|
68
|
+
|
|
69
|
+
return (string) \key($keyVal);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
/**
|
|
73
|
+
* Returns the value from keyVal(), without reset.
|
|
74
|
+
*
|
|
75
|
+
* @return string
|
|
76
|
+
*/
|
|
77
|
+
private function value()
|
|
78
|
+
{
|
|
79
|
+
$keyVal = $this->keyVal();
|
|
80
|
+
|
|
81
|
+
/** @var string */
|
|
82
|
+
return \reset($keyVal);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
public function testRepositoryInstanceOf()
|
|
86
|
+
{
|
|
87
|
+
self::assertInstanceOf(RepositoryInterface::class, RepositoryBuilder::createWithNoAdapters()->make());
|
|
88
|
+
self::assertInstanceOf(RepositoryInterface::class, RepositoryBuilder::createWithDefaultAdapters()->make());
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
public function testMutableLoaderClearsEnvironmentVars()
|
|
92
|
+
{
|
|
93
|
+
$repository = RepositoryBuilder::createWithDefaultAdapters()->make();
|
|
94
|
+
|
|
95
|
+
// Set an environment variable.
|
|
96
|
+
$repository->set($this->key(), $this->value());
|
|
97
|
+
|
|
98
|
+
// Clear the set environment variable.
|
|
99
|
+
$repository->clear($this->key());
|
|
100
|
+
self::assertNull($repository->get($this->key()));
|
|
101
|
+
self::assertFalse(\getenv($this->key()));
|
|
102
|
+
self::assertFalse(isset($_ENV[$this->key()]));
|
|
103
|
+
self::assertFalse(isset($_SERVER[$this->key()]));
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
public function testImmutableLoaderCannotClearExistingEnvironmentVars()
|
|
107
|
+
{
|
|
108
|
+
$this->load();
|
|
109
|
+
|
|
110
|
+
$repository = RepositoryBuilder::createWithDefaultAdapters()->immutable()->make();
|
|
111
|
+
|
|
112
|
+
// Pre-set an environment variable.
|
|
113
|
+
RepositoryBuilder::createWithDefaultAdapters()->make()->set($this->key(), $this->value());
|
|
114
|
+
|
|
115
|
+
// Attempt to clear the environment variable, check that it fails.
|
|
116
|
+
$repository->clear($this->key());
|
|
117
|
+
self::assertSame($this->value(), $repository->get($this->key()));
|
|
118
|
+
self::assertTrue(isset($_ENV[$this->key()]));
|
|
119
|
+
self::assertTrue(isset($_SERVER[$this->key()]));
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
public function testImmutableLoaderCanClearSetEnvironmentVars()
|
|
123
|
+
{
|
|
124
|
+
$this->load();
|
|
125
|
+
|
|
126
|
+
$repository = RepositoryBuilder::createWithDefaultAdapters()->immutable()->make();
|
|
127
|
+
|
|
128
|
+
// Set an environment variable.
|
|
129
|
+
$repository->set($this->key(), $this->value());
|
|
130
|
+
|
|
131
|
+
// Attempt to clear the environment variable, check that it works.
|
|
132
|
+
$repository->clear($this->key());
|
|
133
|
+
self::assertNull($repository->get($this->key()));
|
|
134
|
+
self::assertFalse(\getenv($this->key()));
|
|
135
|
+
self::assertFalse(isset($_ENV[$this->key()]));
|
|
136
|
+
self::assertFalse(isset($_SERVER[$this->key()]));
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
public function testCheckingWhetherVariableExists()
|
|
140
|
+
{
|
|
141
|
+
$this->load();
|
|
142
|
+
|
|
143
|
+
$repo = RepositoryBuilder::createWithDefaultAdapters()->make();
|
|
144
|
+
|
|
145
|
+
self::assertTrue($repo->has('FOO'));
|
|
146
|
+
self::assertFalse($repo->has('NON_EXISTING_VARIABLE'));
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
public function testHasWithBadVariable()
|
|
150
|
+
{
|
|
151
|
+
$repo = RepositoryBuilder::createWithDefaultAdapters()->make();
|
|
152
|
+
|
|
153
|
+
$this->expectException(TypeError::class);
|
|
154
|
+
|
|
155
|
+
$repo->has(null);
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
public function testGettingVariableByName()
|
|
159
|
+
{
|
|
160
|
+
$this->load();
|
|
161
|
+
|
|
162
|
+
$repo = RepositoryBuilder::createWithDefaultAdapters()->make();
|
|
163
|
+
|
|
164
|
+
self::assertSame('bar', $repo->get('FOO'));
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
public function testGettingNullVariable()
|
|
168
|
+
{
|
|
169
|
+
$repo = RepositoryBuilder::createWithDefaultAdapters()->make();
|
|
170
|
+
|
|
171
|
+
$this->expectException(TypeError::class);
|
|
172
|
+
|
|
173
|
+
$repo->get(null);
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
public function testGettingEmptyVariable()
|
|
177
|
+
{
|
|
178
|
+
$repo = RepositoryBuilder::createWithDefaultAdapters()->make();
|
|
179
|
+
|
|
180
|
+
$this->expectException(InvalidArgumentException::class);
|
|
181
|
+
$this->expectExceptionMessage('Expected name to be a non-empty string.');
|
|
182
|
+
|
|
183
|
+
$repo->get('');
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
public function testSettingVariable()
|
|
187
|
+
{
|
|
188
|
+
$this->load();
|
|
189
|
+
|
|
190
|
+
$repo = RepositoryBuilder::createWithDefaultAdapters()->make();
|
|
191
|
+
|
|
192
|
+
self::assertSame('bar', $repo->get('FOO'));
|
|
193
|
+
$repo->set('FOO', 'new');
|
|
194
|
+
self::assertSame('new', $repo->get('FOO'));
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
public function testSettingNullVariable()
|
|
198
|
+
{
|
|
199
|
+
$repo = RepositoryBuilder::createWithDefaultAdapters()->make();
|
|
200
|
+
|
|
201
|
+
$this->expectException(TypeError::class);
|
|
202
|
+
|
|
203
|
+
$repo->set(null, 'foo');
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
public function testSettingEmptyVariable()
|
|
207
|
+
{
|
|
208
|
+
$repo = RepositoryBuilder::createWithDefaultAdapters()->make();
|
|
209
|
+
|
|
210
|
+
$this->expectException(InvalidArgumentException::class);
|
|
211
|
+
$this->expectExceptionMessage('Expected name to be a non-empty string.');
|
|
212
|
+
|
|
213
|
+
$repo->set('', 'foo');
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
public function testClearingVariable()
|
|
217
|
+
{
|
|
218
|
+
$this->load();
|
|
219
|
+
|
|
220
|
+
$repo = RepositoryBuilder::createWithDefaultAdapters()->make();
|
|
221
|
+
|
|
222
|
+
self::assertTrue($repo->has('FOO'));
|
|
223
|
+
$repo->clear('FOO');
|
|
224
|
+
self::assertFalse($repo->has('FOO'));
|
|
225
|
+
}
|
|
226
|
+
|
|
227
|
+
public function testClearingVariableWithArrayAdapter()
|
|
228
|
+
{
|
|
229
|
+
$adapter = ArrayAdapter::create()->get();
|
|
230
|
+
$repo = RepositoryBuilder::createWithNoAdapters()->addReader($adapter)->addWriter($adapter)->make();
|
|
231
|
+
|
|
232
|
+
self::assertFalse($repo->has('FOO'));
|
|
233
|
+
$repo->set('FOO', 'BAR');
|
|
234
|
+
self::assertTrue($repo->has('FOO'));
|
|
235
|
+
$repo->clear('FOO');
|
|
236
|
+
self::assertFalse($repo->has('FOO'));
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
public function testClearingNullVariable()
|
|
240
|
+
{
|
|
241
|
+
$repo = RepositoryBuilder::createWithDefaultAdapters()->make();
|
|
242
|
+
|
|
243
|
+
$this->expectException(TypeError::class);
|
|
244
|
+
|
|
245
|
+
$repo->clear(null);
|
|
246
|
+
}
|
|
247
|
+
|
|
248
|
+
public function testClearingEmptyVariable()
|
|
249
|
+
{
|
|
250
|
+
$repo = RepositoryBuilder::createWithDefaultAdapters()->make();
|
|
251
|
+
|
|
252
|
+
$this->expectException(InvalidArgumentException::class);
|
|
253
|
+
$this->expectExceptionMessage('Expected name to be a non-empty string.');
|
|
254
|
+
|
|
255
|
+
$repo->clear('');
|
|
256
|
+
}
|
|
257
|
+
|
|
258
|
+
public function testCannotSetVariableOnImmutableInstance()
|
|
259
|
+
{
|
|
260
|
+
$this->load();
|
|
261
|
+
|
|
262
|
+
$repo = RepositoryBuilder::createWithDefaultAdapters()->immutable()->make();
|
|
263
|
+
|
|
264
|
+
self::assertSame('bar', $repo->get('FOO'));
|
|
265
|
+
|
|
266
|
+
$repo->set('FOO', 'new');
|
|
267
|
+
|
|
268
|
+
self::assertSame('bar', $repo->get('FOO'));
|
|
269
|
+
}
|
|
270
|
+
|
|
271
|
+
public function testCannotClearVariableOnImmutableInstance()
|
|
272
|
+
{
|
|
273
|
+
$this->load();
|
|
274
|
+
|
|
275
|
+
$repo = RepositoryBuilder::createWithDefaultAdapters()->immutable()->make();
|
|
276
|
+
|
|
277
|
+
$repo->clear('FOO');
|
|
278
|
+
|
|
279
|
+
self::assertTrue($repo->has('FOO'));
|
|
280
|
+
}
|
|
281
|
+
|
|
282
|
+
public function testBuildWithBadReader()
|
|
283
|
+
{
|
|
284
|
+
$this->expectException(InvalidArgumentException::class);
|
|
285
|
+
$this->expectExceptionMessage('Expected either an instance of ');
|
|
286
|
+
|
|
287
|
+
RepositoryBuilder::createWithNoAdapters()->addReader('123');
|
|
288
|
+
}
|
|
289
|
+
|
|
290
|
+
public function testBuildWithBadWriter()
|
|
291
|
+
{
|
|
292
|
+
$this->expectException(InvalidArgumentException::class);
|
|
293
|
+
$this->expectExceptionMessage('Expected either an instance of ');
|
|
294
|
+
|
|
295
|
+
RepositoryBuilder::createWithNoAdapters()->addWriter('123');
|
|
296
|
+
}
|
|
297
|
+
|
|
298
|
+
public function testBuildWithBadAdapter()
|
|
299
|
+
{
|
|
300
|
+
$this->expectException(InvalidArgumentException::class);
|
|
301
|
+
$this->expectExceptionMessage('Expected either an instance of ');
|
|
302
|
+
|
|
303
|
+
RepositoryBuilder::createWithNoAdapters()->addAdapter('');
|
|
304
|
+
}
|
|
305
|
+
}
|
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
|
|
3
|
+
declare(strict_types=1);
|
|
4
|
+
|
|
5
|
+
namespace Dotenv\Tests\Store;
|
|
6
|
+
|
|
7
|
+
use Dotenv\Exception\InvalidEncodingException;
|
|
8
|
+
use Dotenv\Store\File\Paths;
|
|
9
|
+
use Dotenv\Store\File\Reader;
|
|
10
|
+
use Dotenv\Store\StoreBuilder;
|
|
11
|
+
use PHPUnit\Framework\TestCase;
|
|
12
|
+
|
|
13
|
+
final class StoreTest extends TestCase
|
|
14
|
+
{
|
|
15
|
+
/**
|
|
16
|
+
* @var string
|
|
17
|
+
*/
|
|
18
|
+
private static $folder;
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* @beforeClass
|
|
22
|
+
*
|
|
23
|
+
* @return void
|
|
24
|
+
*/
|
|
25
|
+
public static function setFolder()
|
|
26
|
+
{
|
|
27
|
+
self::$folder = \dirname(\dirname(__DIR__)).'/fixtures/env';
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
public function testBasicReadDirect()
|
|
31
|
+
{
|
|
32
|
+
self::assertSame(
|
|
33
|
+
[
|
|
34
|
+
self::$folder.\DIRECTORY_SEPARATOR.'.env' => "FOO=bar\nBAR=baz\nSPACED=\"with spaces\"\n\nNULL=\n",
|
|
35
|
+
],
|
|
36
|
+
Reader::read(
|
|
37
|
+
Paths::filePaths([self::$folder], ['.env'])
|
|
38
|
+
)
|
|
39
|
+
);
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
public function testBasicRead()
|
|
43
|
+
{
|
|
44
|
+
$builder = StoreBuilder::createWithDefaultName()
|
|
45
|
+
->addPath(self::$folder);
|
|
46
|
+
|
|
47
|
+
self::assertSame(
|
|
48
|
+
"FOO=bar\nBAR=baz\nSPACED=\"with spaces\"\n\nNULL=\n",
|
|
49
|
+
$builder->make()->read()
|
|
50
|
+
);
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
public function testBasicReadWindowsEncoding()
|
|
54
|
+
{
|
|
55
|
+
$builder = StoreBuilder::createWithNoNames()
|
|
56
|
+
->addPath(self::$folder)
|
|
57
|
+
->addName('windows.env')
|
|
58
|
+
->fileEncoding('Windows-1252');
|
|
59
|
+
|
|
60
|
+
self::assertSame(
|
|
61
|
+
"MBW=\"ñá\"\n",
|
|
62
|
+
$builder->make()->read()
|
|
63
|
+
);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
public function testBasicReadBadEncoding()
|
|
67
|
+
{
|
|
68
|
+
$builder = StoreBuilder::createWithNoNames()
|
|
69
|
+
->addPath(self::$folder)
|
|
70
|
+
->addName('windows.env')
|
|
71
|
+
->fileEncoding('Windowss-1252');
|
|
72
|
+
|
|
73
|
+
$this->expectException(InvalidEncodingException::class);
|
|
74
|
+
$this->expectExceptionMessage('Illegal character encoding [Windowss-1252] specified.');
|
|
75
|
+
|
|
76
|
+
$builder->make()->read();
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
public function testFileReadMultipleShortCircuitModeDirect()
|
|
80
|
+
{
|
|
81
|
+
self::assertSame(
|
|
82
|
+
[
|
|
83
|
+
self::$folder.\DIRECTORY_SEPARATOR.'.env' => "FOO=bar\nBAR=baz\nSPACED=\"with spaces\"\n\nNULL=\n",
|
|
84
|
+
],
|
|
85
|
+
Reader::read(
|
|
86
|
+
Paths::filePaths([self::$folder], ['.env', 'example.env'])
|
|
87
|
+
)
|
|
88
|
+
);
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
public function testFileReadMultipleShortCircuitMode()
|
|
92
|
+
{
|
|
93
|
+
$builder = StoreBuilder::createWithNoNames()
|
|
94
|
+
->addPath(self::$folder)
|
|
95
|
+
->addName('.env')
|
|
96
|
+
->addName('example.env')
|
|
97
|
+
->shortCircuit();
|
|
98
|
+
|
|
99
|
+
self::assertSame(
|
|
100
|
+
"FOO=bar\nBAR=baz\nSPACED=\"with spaces\"\n\nNULL=\n",
|
|
101
|
+
$builder->make()->read()
|
|
102
|
+
);
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
public function testFileReadMultipleWithoutShortCircuitModeDirect()
|
|
106
|
+
{
|
|
107
|
+
self::assertSame(
|
|
108
|
+
[
|
|
109
|
+
self::$folder.\DIRECTORY_SEPARATOR.'.env' => "FOO=bar\nBAR=baz\nSPACED=\"with spaces\"\n\nNULL=\n",
|
|
110
|
+
self::$folder.\DIRECTORY_SEPARATOR.'example.env' => "EG=\"example\"\n",
|
|
111
|
+
],
|
|
112
|
+
Reader::read(
|
|
113
|
+
Paths::filePaths([self::$folder], ['.env', 'example.env']),
|
|
114
|
+
false
|
|
115
|
+
)
|
|
116
|
+
);
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
public function testFileReadMultipleWithoutShortCircuitMode()
|
|
120
|
+
{
|
|
121
|
+
$builder = StoreBuilder::createWithDefaultName()
|
|
122
|
+
->addPath(self::$folder)
|
|
123
|
+
->addName('example.env');
|
|
124
|
+
|
|
125
|
+
self::assertSame(
|
|
126
|
+
"FOO=bar\nBAR=baz\nSPACED=\"with spaces\"\n\nNULL=\n\nEG=\"example\"\n",
|
|
127
|
+
$builder->make()->read()
|
|
128
|
+
);
|
|
129
|
+
}
|
|
130
|
+
public function testFileReadWithUtf8WithBomEncoding()
|
|
131
|
+
{
|
|
132
|
+
self::assertSame(
|
|
133
|
+
[
|
|
134
|
+
self::$folder.\DIRECTORY_SEPARATOR.'utf8-with-bom-encoding.env' => "FOO=bar\nBAR=baz\nSPACED=\"with spaces\"\n",
|
|
135
|
+
],
|
|
136
|
+
Reader::read(
|
|
137
|
+
Paths::filePaths([self::$folder], ['utf8-with-bom-encoding.env'])
|
|
138
|
+
)
|
|
139
|
+
);
|
|
140
|
+
}
|
|
141
|
+
}
|