create-berna-stencil 1.0.8 → 1.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/.eleventy.js +3 -1
- package/.env.example +8 -0
- package/.gitignore +2 -1
- package/README.md +1 -5
- package/bin/create.js +2 -1
- package/package.json +71 -70
- package/src/.htaccess +18 -0
- package/src/api/.htaccess +12 -0
- package/src/api/composer.json +6 -0
- package/src/api/composer.lock +574 -0
- package/src/api/endpoints/protected/secret.php +16 -0
- package/src/api/endpoints/protected/send-mail.php +75 -0
- package/src/api/endpoints/public/ping.php +16 -0
- package/src/api/index.php +95 -0
- package/src/api/init.php +43 -0
- package/src/api/modules/Response.php +37 -0
- package/src/api/vendor/autoload.php +22 -0
- package/src/api/vendor/composer/ClassLoader.php +579 -0
- package/src/api/vendor/composer/InstalledVersions.php +396 -0
- package/src/api/vendor/composer/LICENSE +21 -0
- package/src/api/vendor/composer/autoload_classmap.php +15 -0
- package/src/api/vendor/composer/autoload_files.php +12 -0
- package/src/api/vendor/composer/autoload_namespaces.php +9 -0
- package/src/api/vendor/composer/autoload_psr4.php +16 -0
- package/src/api/vendor/composer/autoload_real.php +50 -0
- package/src/api/vendor/composer/autoload_static.php +86 -0
- package/src/api/vendor/composer/installed.json +582 -0
- package/src/api/vendor/composer/installed.php +86 -0
- package/src/api/vendor/composer/platform_check.php +25 -0
- package/src/api/vendor/graham-campbell/result-type/.gitattributes +9 -0
- package/src/api/vendor/graham-campbell/result-type/.github/CODE_OF_CONDUCT.md +132 -0
- package/src/api/vendor/graham-campbell/result-type/.github/CONTRIBUTING.md +31 -0
- package/src/api/vendor/graham-campbell/result-type/.github/FUNDING.yml +2 -0
- package/src/api/vendor/graham-campbell/result-type/.github/SECURITY.md +14 -0
- package/src/api/vendor/graham-campbell/result-type/.github/workflows/stale.yml +11 -0
- package/src/api/vendor/graham-campbell/result-type/.github/workflows/tests.yml +40 -0
- package/src/api/vendor/graham-campbell/result-type/CHANGELOG.md +53 -0
- package/src/api/vendor/graham-campbell/result-type/LICENSE +21 -0
- package/src/api/vendor/graham-campbell/result-type/README.md +42 -0
- package/src/api/vendor/graham-campbell/result-type/composer.json +33 -0
- package/src/api/vendor/graham-campbell/result-type/phpunit.xml.dist +13 -0
- package/src/api/vendor/graham-campbell/result-type/src/Error.php +121 -0
- package/src/api/vendor/graham-campbell/result-type/src/Result.php +69 -0
- package/src/api/vendor/graham-campbell/result-type/src/Success.php +120 -0
- package/src/api/vendor/graham-campbell/result-type/tests/ResultTest.php +95 -0
- package/src/api/vendor/phpmailer/phpmailer/.codecov.yml +21 -0
- package/src/api/vendor/phpmailer/phpmailer/.editorconfig +15 -0
- package/src/api/vendor/phpmailer/phpmailer/.gitattributes +17 -0
- package/src/api/vendor/phpmailer/phpmailer/.github/FUNDING.yml +6 -0
- package/src/api/vendor/phpmailer/phpmailer/.github/ISSUE_TEMPLATE/bug_report.md +23 -0
- package/src/api/vendor/phpmailer/phpmailer/.github/actions/build-docs/Dockerfile +15 -0
- package/src/api/vendor/phpmailer/phpmailer/.github/actions/build-docs/entrypoint.sh +5 -0
- package/src/api/vendor/phpmailer/phpmailer/.github/dependabot.yml +21 -0
- package/src/api/vendor/phpmailer/phpmailer/.github/workflows/docs.yaml +30 -0
- package/src/api/vendor/phpmailer/phpmailer/.github/workflows/scorecards.yml +61 -0
- package/src/api/vendor/phpmailer/phpmailer/.github/workflows/tests.yml +237 -0
- package/src/api/vendor/phpmailer/phpmailer/.phan/config.php +41 -0
- package/src/api/vendor/phpmailer/phpmailer/COMMITMENT +46 -0
- package/src/api/vendor/phpmailer/phpmailer/LICENSE +502 -0
- package/src/api/vendor/phpmailer/phpmailer/README.md +232 -0
- package/src/api/vendor/phpmailer/phpmailer/SECURITY.md +37 -0
- package/src/api/vendor/phpmailer/phpmailer/SMTPUTF8.md +48 -0
- package/src/api/vendor/phpmailer/phpmailer/UPGRADING.md +125 -0
- package/src/api/vendor/phpmailer/phpmailer/VERSION +1 -0
- package/src/api/vendor/phpmailer/phpmailer/changelog.md +1122 -0
- package/src/api/vendor/phpmailer/phpmailer/composer.json +84 -0
- package/src/api/vendor/phpmailer/phpmailer/docs/README.md +9 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/DKIM_gen_keys.phps +81 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/DKIM_sign.phps +46 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/README.md +96 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/azure_xoauth2.phps +126 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/callback.phps +76 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/contactform-ajax.phps +146 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/contactform.phps +95 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/contents.html +17 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/contentsutf8.html +23 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/exceptions.phps +40 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/extending.phps +72 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/gmail.phps +106 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/gmail_xoauth.phps +121 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/images/PHPMailer card logo.afdesign +0 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/images/PHPMailer card logo.png +0 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/images/PHPMailer card logo.svg +209 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/images/phpmailer.png +0 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/images/phpmailer_mini.png +0 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/mail.phps +35 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/mailing_list.phps +96 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/pop_before_smtp.phps +60 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/send_file_upload.phps +60 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/send_multiple_file_upload.phps +60 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/sendmail.phps +37 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/sendoauth2.phps +100 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/simple_contact_form.phps +102 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/smime_signed_mail.phps +99 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/smtp.phps +62 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/smtp_check.phps +60 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/smtp_low_memory.phps +117 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/smtp_no_auth.phps +53 -0
- package/src/api/vendor/phpmailer/phpmailer/examples/ssl_options.phps +81 -0
- package/src/api/vendor/phpmailer/phpmailer/get_oauth_token.php +182 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-af.php +26 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-ar.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-as.php +35 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-az.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-ba.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-be.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-bg.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-bn.php +35 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-ca.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-cs.php +28 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-da.php +39 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-de.php +28 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-el.php +33 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-eo.php +37 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-es.php +38 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-et.php +28 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-fa.php +28 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-fi.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-fo.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-fr.php +36 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-gl.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-he.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-hi.php +35 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-hr.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-hu.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-hy.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-id.php +31 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-it.php +28 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-ja.php +37 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-ka.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-ko.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-ku.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-lt.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-lv.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-mg.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-mn.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-ms.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-nb.php +37 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-nl.php +38 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-pl.php +33 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-pt.php +34 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-pt_br.php +38 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-ro.php +33 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-ru.php +36 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-si.php +34 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-sk.php +30 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-sl.php +36 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-sr.php +28 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-sr_latn.php +28 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-sv.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-tl.php +28 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-tr.php +38 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-uk.php +28 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-ur.php +30 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-vi.php +27 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-zh.php +29 -0
- package/src/api/vendor/phpmailer/phpmailer/language/phpmailer.lang-zh_cn.php +36 -0
- package/src/api/vendor/phpmailer/phpmailer/phpcs.xml.dist +52 -0
- package/src/api/vendor/phpmailer/phpmailer/phpdoc.dist.xml +20 -0
- package/src/api/vendor/phpmailer/phpmailer/phpunit.xml.dist +36 -0
- package/src/api/vendor/phpmailer/phpmailer/src/DSNConfigurator.php +245 -0
- package/src/api/vendor/phpmailer/phpmailer/src/Exception.php +40 -0
- package/src/api/vendor/phpmailer/phpmailer/src/OAuth.php +139 -0
- package/src/api/vendor/phpmailer/phpmailer/src/OAuthTokenProvider.php +44 -0
- package/src/api/vendor/phpmailer/phpmailer/src/PHPMailer.php +5525 -0
- package/src/api/vendor/phpmailer/phpmailer/src/POP3.php +470 -0
- package/src/api/vendor/phpmailer/phpmailer/src/SMTP.php +1617 -0
- package/src/api/vendor/phpmailer/phpmailer/test/DebugLogTestListener.php +47 -0
- package/src/api/vendor/phpmailer/phpmailer/test/Fixtures/FileIsAccessibleTest/accessible.txt +1 -0
- package/src/api/vendor/phpmailer/phpmailer/test/Fixtures/FileIsAccessibleTest/inaccessible.txt +1 -0
- package/src/api/vendor/phpmailer/phpmailer/test/Fixtures/LocalizationTest/phpmailer.lang-fr.php +10 -0
- package/src/api/vendor/phpmailer/phpmailer/test/Fixtures/LocalizationTest/phpmailer.lang-nl.php +10 -0
- package/src/api/vendor/phpmailer/phpmailer/test/Fixtures/LocalizationTest/phpmailer.lang-xa_scri_cc.php +9 -0
- package/src/api/vendor/phpmailer/phpmailer/test/Fixtures/LocalizationTest/phpmailer.lang-xb_scri.php +9 -0
- package/src/api/vendor/phpmailer/phpmailer/test/Fixtures/LocalizationTest/phpmailer.lang-xc_cc.php +9 -0
- package/src/api/vendor/phpmailer/phpmailer/test/Fixtures/LocalizationTest/phpmailer.lang-xd_cc.php +9 -0
- package/src/api/vendor/phpmailer/phpmailer/test/Fixtures/LocalizationTest/phpmailer.lang-xd_scri.php +9 -0
- package/src/api/vendor/phpmailer/phpmailer/test/Fixtures/LocalizationTest/phpmailer.lang-xe.php +9 -0
- package/src/api/vendor/phpmailer/phpmailer/test/Fixtures/LocalizationTest/phpmailer.lang-xx.php +9 -0
- package/src/api/vendor/phpmailer/phpmailer/test/Fixtures/LocalizationTest/phpmailer.lang-yy.php +16 -0
- package/src/api/vendor/phpmailer/phpmailer/test/Fixtures/LocalizationTest/phpmailer.lang-yz.php +16 -0
- package/src/api/vendor/phpmailer/phpmailer/test/Fixtures/LocalizationTest/phpmailer.lang-zz.php +20 -0
- package/src/api/vendor/phpmailer/phpmailer/test/Language/TranslationCompletenessTest.php +97 -0
- package/src/api/vendor/phpmailer/phpmailer/test/OAuth/OAuthTest.php +76 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/AddEmbeddedImageTest.php +178 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/AddStringAttachmentTest.php +147 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/AddStringEmbeddedImageTest.php +161 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/AddrFormatTest.php +70 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/AuthCRAMMD5Test.php +48 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/CustomHeaderTest.php +285 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/DKIMTest.php +258 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/DKIMWithoutExceptionsTest.php +46 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/DSNConfiguratorTest.php +221 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/EncodeQTest.php +110 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/EncodeStringTest.php +135 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/FileIsAccessibleTest.php +103 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/FilenameToTypeTest.php +74 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/GenerateIdTest.php +75 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/GetLastMessageIDTest.php +110 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/HasLineLongerThanMaxTest.php +158 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/Html2TextTest.php +231 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/ICalTest.php +126 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/IsPermittedPathTest.php +108 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/IsValidHostTest.php +107 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/LocalizationTest.php +505 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/MailTransportTest.php +261 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/MbPathinfoTest.php +171 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/MimeTypesTest.php +70 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/NormalizeBreaksTest.php +111 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/PHPMailerTest.php +1388 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/ParseAddressesTest.php +321 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/PunyencodeAddressTest.php +141 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/QuotedStringTest.php +70 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/ReplyToGetSetClearTest.php +444 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/SetErrorTest.php +154 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/SetFromTest.php +202 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/SetTest.php +81 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/SetWordWrapTest.php +120 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/Utf8CharBoundaryTest.php +66 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/ValidateAddressCustomValidatorTest.php +116 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/ValidateAddressTest.php +485 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/WrapTextTest.php +125 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PHPMailer/XMailerTest.php +75 -0
- package/src/api/vendor/phpmailer/phpmailer/test/POP3/PopBeforeSmtpTest.php +139 -0
- package/src/api/vendor/phpmailer/phpmailer/test/PreSendTestCase.php +46 -0
- package/src/api/vendor/phpmailer/phpmailer/test/Security/DenialOfServiceVectorsTest.php +52 -0
- package/src/api/vendor/phpmailer/phpmailer/test/SendTestCase.php +126 -0
- package/src/api/vendor/phpmailer/phpmailer/test/TestCase.php +392 -0
- package/src/api/vendor/phpmailer/phpmailer/test/fakepopserver.sh +126 -0
- package/src/api/vendor/phpmailer/phpmailer/test/fakesendmail.sh +22 -0
- package/src/api/vendor/phpmailer/phpmailer/test/runfakepopserver.sh +12 -0
- package/src/api/vendor/phpmailer/phpmailer/test/testbootstrap-dist.php +8 -0
- package/src/api/vendor/phpmailer/phpmailer/test/validators.php +12 -0
- package/src/api/vendor/phpoption/phpoption/.gitattributes +13 -0
- package/src/api/vendor/phpoption/phpoption/.github/CODE_OF_CONDUCT.md +132 -0
- package/src/api/vendor/phpoption/phpoption/.github/CONTRIBUTING.md +30 -0
- package/src/api/vendor/phpoption/phpoption/.github/FUNDING.yml +2 -0
- package/src/api/vendor/phpoption/phpoption/.github/SECURITY.md +14 -0
- package/src/api/vendor/phpoption/phpoption/.github/workflows/static.yml +40 -0
- package/src/api/vendor/phpoption/phpoption/.github/workflows/tests.yml +40 -0
- package/src/api/vendor/phpoption/phpoption/LICENSE +201 -0
- package/src/api/vendor/phpoption/phpoption/Makefile +17 -0
- package/src/api/vendor/phpoption/phpoption/README.md +201 -0
- package/src/api/vendor/phpoption/phpoption/composer.json +50 -0
- package/src/api/vendor/phpoption/phpoption/phpstan-baseline.neon +44 -0
- package/src/api/vendor/phpoption/phpoption/phpstan.neon.dist +7 -0
- package/src/api/vendor/phpoption/phpoption/phpunit.xml.dist +13 -0
- package/src/api/vendor/phpoption/phpoption/src/PhpOption/LazyOption.php +175 -0
- package/src/api/vendor/phpoption/phpoption/src/PhpOption/None.php +136 -0
- package/src/api/vendor/phpoption/phpoption/src/PhpOption/Option.php +434 -0
- package/src/api/vendor/phpoption/phpoption/src/PhpOption/Some.php +169 -0
- package/src/api/vendor/phpoption/phpoption/tests/PhpOption/Tests/EnsureTest.php +72 -0
- package/src/api/vendor/phpoption/phpoption/tests/PhpOption/Tests/LazyOptionTest.php +357 -0
- package/src/api/vendor/phpoption/phpoption/tests/PhpOption/Tests/NoneTest.php +153 -0
- package/src/api/vendor/phpoption/phpoption/tests/PhpOption/Tests/OptionTest.php +166 -0
- package/src/api/vendor/phpoption/phpoption/tests/PhpOption/Tests/SomeTest.php +194 -0
- package/src/api/vendor/phpoption/phpoption/tests/bootstrap.php +8 -0
- package/src/api/vendor/phpoption/phpoption/vendor-bin/phpstan/composer.json +8 -0
- package/src/api/vendor/symfony/polyfill-ctype/Ctype.php +232 -0
- package/src/api/vendor/symfony/polyfill-ctype/LICENSE +19 -0
- package/src/api/vendor/symfony/polyfill-ctype/README.md +12 -0
- package/src/api/vendor/symfony/polyfill-ctype/bootstrap.php +50 -0
- package/src/api/vendor/symfony/polyfill-ctype/bootstrap80.php +46 -0
- package/src/api/vendor/symfony/polyfill-ctype/composer.json +38 -0
- package/src/api/vendor/symfony/polyfill-mbstring/LICENSE +19 -0
- package/src/api/vendor/symfony/polyfill-mbstring/Mbstring.php +1077 -0
- package/src/api/vendor/symfony/polyfill-mbstring/README.md +13 -0
- package/src/api/vendor/symfony/polyfill-mbstring/Resources/unidata/caseFolding.php +119 -0
- package/src/api/vendor/symfony/polyfill-mbstring/Resources/unidata/lowerCase.php +1397 -0
- package/src/api/vendor/symfony/polyfill-mbstring/Resources/unidata/titleCaseRegexp.php +5 -0
- package/src/api/vendor/symfony/polyfill-mbstring/Resources/unidata/upperCase.php +1489 -0
- package/src/api/vendor/symfony/polyfill-mbstring/bootstrap.php +171 -0
- package/src/api/vendor/symfony/polyfill-mbstring/bootstrap80.php +167 -0
- package/src/api/vendor/symfony/polyfill-mbstring/composer.json +39 -0
- package/src/api/vendor/symfony/polyfill-php80/LICENSE +19 -0
- package/src/api/vendor/symfony/polyfill-php80/Php80.php +115 -0
- package/src/api/vendor/symfony/polyfill-php80/PhpToken.php +106 -0
- package/src/api/vendor/symfony/polyfill-php80/README.md +25 -0
- package/src/api/vendor/symfony/polyfill-php80/Resources/stubs/Attribute.php +31 -0
- package/src/api/vendor/symfony/polyfill-php80/Resources/stubs/PhpToken.php +16 -0
- package/src/api/vendor/symfony/polyfill-php80/Resources/stubs/Stringable.php +20 -0
- package/src/api/vendor/symfony/polyfill-php80/Resources/stubs/UnhandledMatchError.php +16 -0
- package/src/api/vendor/symfony/polyfill-php80/Resources/stubs/ValueError.php +16 -0
- package/src/api/vendor/symfony/polyfill-php80/bootstrap.php +42 -0
- package/src/api/vendor/symfony/polyfill-php80/composer.json +37 -0
- package/src/api/vendor/vlucas/phpdotenv/.editorconfig +15 -0
- package/src/api/vendor/vlucas/phpdotenv/.gitattributes +15 -0
- package/src/api/vendor/vlucas/phpdotenv/.github/CODE_OF_CONDUCT.md +132 -0
- package/src/api/vendor/vlucas/phpdotenv/.github/CONTRIBUTING.md +30 -0
- package/src/api/vendor/vlucas/phpdotenv/.github/FUNDING.yml +2 -0
- package/src/api/vendor/vlucas/phpdotenv/.github/SECURITY.md +14 -0
- package/src/api/vendor/vlucas/phpdotenv/.github/workflows/static.yml +40 -0
- package/src/api/vendor/vlucas/phpdotenv/.github/workflows/tests.yml +70 -0
- package/src/api/vendor/vlucas/phpdotenv/LICENSE +30 -0
- package/src/api/vendor/vlucas/phpdotenv/Makefile +17 -0
- package/src/api/vendor/vlucas/phpdotenv/README.md +370 -0
- package/src/api/vendor/vlucas/phpdotenv/UPGRADING.md +196 -0
- package/src/api/vendor/vlucas/phpdotenv/composer.json +60 -0
- package/src/api/vendor/vlucas/phpdotenv/phpstan-baseline.neon +157 -0
- package/src/api/vendor/vlucas/phpdotenv/phpstan.neon.dist +7 -0
- package/src/api/vendor/vlucas/phpdotenv/phpunit.xml.dist +13 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Dotenv.php +267 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Exception/ExceptionInterface.php +12 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Exception/InvalidEncodingException.php +12 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Exception/InvalidFileException.php +12 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Exception/InvalidPathException.php +12 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Exception/ValidationException.php +12 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Loader/Loader.php +48 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Loader/LoaderInterface.php +20 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Loader/Resolver.php +65 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Parser/Entry.php +59 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Parser/EntryParser.php +299 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Parser/Lexer.php +58 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Parser/Lines.php +127 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Parser/Parser.php +53 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Parser/ParserInterface.php +19 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Parser/Value.php +88 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Repository/Adapter/AdapterInterface.php +15 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Repository/Adapter/ApacheAdapter.php +89 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Repository/Adapter/ArrayAdapter.php +80 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Repository/Adapter/EnvConstAdapter.php +88 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Repository/Adapter/GuardedWriter.php +85 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Repository/Adapter/ImmutableWriter.php +110 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Repository/Adapter/MultiReader.php +48 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Repository/Adapter/MultiWriter.php +64 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Repository/Adapter/PutenvAdapter.php +91 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Repository/Adapter/ReaderInterface.php +17 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Repository/Adapter/ReplacingWriter.php +104 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Repository/Adapter/ServerConstAdapter.php +88 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Repository/Adapter/WriterInterface.php +27 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Repository/AdapterRepository.php +107 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Repository/RepositoryBuilder.php +272 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Repository/RepositoryInterface.php +51 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Store/File/Paths.php +44 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Store/File/Reader.php +81 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Store/FileStore.php +72 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Store/StoreBuilder.php +141 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Store/StoreInterface.php +17 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Store/StringStore.php +37 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Util/Regex.php +112 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Util/Str.php +108 -0
- package/src/api/vendor/vlucas/phpdotenv/src/Validator.php +207 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/Dotenv/DotenvTest.php +387 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/Dotenv/Loader/LoaderTest.php +86 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/Dotenv/Parser/EntryParserTest.php +234 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/Dotenv/Parser/LexerTest.php +40 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/Dotenv/Parser/LinesTest.php +53 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/Dotenv/Parser/ParserTest.php +98 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/Adapter/ArrayAdapterTest.php +57 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/Adapter/EnvConstAdapterTest.php +75 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/Adapter/PutenvAdapterTest.php +52 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/Adapter/ServerConstAdapterTest.php +75 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/RepositoryTest.php +305 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/Dotenv/Store/StoreTest.php +141 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/Dotenv/ValidatorTest.php +479 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/fixtures/env/.env +5 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/fixtures/env/assertions.env +18 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/fixtures/env/booleans.env +33 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/fixtures/env/commented.env +15 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/fixtures/env/empty.env +1 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/fixtures/env/example.env +1 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/fixtures/env/exported.env +7 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/fixtures/env/immutable.env +1 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/fixtures/env/integers.env +17 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/fixtures/env/large.env +2 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/fixtures/env/multibyte.env +3 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/fixtures/env/multiline.env +14 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/fixtures/env/multiple.env +4 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/fixtures/env/mutable.env +1 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/fixtures/env/nested.env +15 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/fixtures/env/quoted.env +11 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/fixtures/env/specialchars.env +8 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/fixtures/env/unicodevarnames.env +2 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/fixtures/env/utf8-with-bom-encoding.env +3 -0
- package/src/api/vendor/vlucas/phpdotenv/tests/fixtures/env/windows.env +1 -0
- package/src/api/vendor/vlucas/phpdotenv/vendor-bin/phpstan/composer.json +15 -0
- package/src/api/configExample.php +0 -28
- package/src/api/sendEmail.php +0 -131
|
@@ -0,0 +1,234 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
|
|
3
|
+
declare(strict_types=1);
|
|
4
|
+
|
|
5
|
+
namespace Dotenv\Tests\Parser;
|
|
6
|
+
|
|
7
|
+
use Dotenv\Parser\Entry;
|
|
8
|
+
use Dotenv\Parser\EntryParser;
|
|
9
|
+
use Dotenv\Parser\Value;
|
|
10
|
+
use GrahamCampbell\ResultType\Result;
|
|
11
|
+
use PHPUnit\Framework\TestCase;
|
|
12
|
+
|
|
13
|
+
final class EntryParserTest extends TestCase
|
|
14
|
+
{
|
|
15
|
+
public function testBasicParse()
|
|
16
|
+
{
|
|
17
|
+
$result = EntryParser::parse('FOO=BAR');
|
|
18
|
+
$this->checkPositiveResult($result, 'FOO', 'BAR');
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
public function testNullParse()
|
|
22
|
+
{
|
|
23
|
+
$result = EntryParser::parse('FOO');
|
|
24
|
+
$this->checkEmptyResult($result, 'FOO');
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
public function testUnicodeNameParse()
|
|
28
|
+
{
|
|
29
|
+
$result = EntryParser::parse('FOOƱ=BAZ');
|
|
30
|
+
$this->checkPositiveResult($result, 'FOOƱ', 'BAZ');
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
public function testQuotesParse()
|
|
34
|
+
{
|
|
35
|
+
$result = EntryParser::parse("FOO=\"BAR \n\"");
|
|
36
|
+
$this->checkPositiveResult($result, 'FOO', "BAR \n");
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
public function testNewlineParse()
|
|
40
|
+
{
|
|
41
|
+
$result = EntryParser::parse('FOO="\n"');
|
|
42
|
+
$this->checkPositiveResult($result, 'FOO', "\n");
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
public function testTabParseDouble()
|
|
46
|
+
{
|
|
47
|
+
$result = EntryParser::parse('FOO="\t"');
|
|
48
|
+
$this->checkPositiveResult($result, 'FOO', "\t");
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
public function testTabParseSingle()
|
|
52
|
+
{
|
|
53
|
+
$result = EntryParser::parse('FOO=\'\t\'');
|
|
54
|
+
$this->checkPositiveResult($result, 'FOO', '\t');
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
public function testNonEscapeParse1()
|
|
58
|
+
{
|
|
59
|
+
$result = EntryParser::parse('FOO=\n\v');
|
|
60
|
+
$this->checkPositiveResult($result, 'FOO', '\n\v');
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
public function testNonEscapeParse2()
|
|
64
|
+
{
|
|
65
|
+
$result = EntryParser::parse('FOO=\q');
|
|
66
|
+
$this->checkPositiveResult($result, 'FOO', '\q');
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
public function testBadEscapeParse()
|
|
70
|
+
{
|
|
71
|
+
$result = EntryParser::parse('FOO="\q"');
|
|
72
|
+
$this->checkErrorResult($result, 'Encountered an unexpected escape sequence at ["\q"].');
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
public function testInlineVariable()
|
|
76
|
+
{
|
|
77
|
+
$result = EntryParser::parse('FOO=$BAR');
|
|
78
|
+
$this->checkPositiveResult($result, 'FOO', '$BAR', [0]);
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
public function testInlineVariableOffset()
|
|
82
|
+
{
|
|
83
|
+
$result = EntryParser::parse('FOO=AAA$BAR');
|
|
84
|
+
$this->checkPositiveResult($result, 'FOO', 'AAA$BAR', [3]);
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
public function testInlineVariables()
|
|
88
|
+
{
|
|
89
|
+
$result = EntryParser::parse('FOO="TEST $BAR $$BAZ"');
|
|
90
|
+
$this->checkPositiveResult($result, 'FOO', 'TEST $BAR $$BAZ', [11, 10, 5]);
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
public function testNonInlineVariable()
|
|
94
|
+
{
|
|
95
|
+
$result = EntryParser::parse('FOO=\'TEST $BAR $$BAZ\'');
|
|
96
|
+
$this->checkPositiveResult($result, 'FOO', 'TEST $BAR $$BAZ');
|
|
97
|
+
self::assertTrue($result->success()->isDefined());
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
public function testWhitespaceParse()
|
|
101
|
+
{
|
|
102
|
+
$result = EntryParser::parse("FOO=\"\n\"");
|
|
103
|
+
$this->checkPositiveResult($result, 'FOO', "\n");
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
public function testExportParse()
|
|
107
|
+
{
|
|
108
|
+
$result = EntryParser::parse('export FOO="bar baz"');
|
|
109
|
+
$this->checkPositiveResult($result, 'FOO', 'bar baz');
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
public function testExportParseTab()
|
|
113
|
+
{
|
|
114
|
+
$result = EntryParser::parse("export\t\"FOO\"='bar baz'");
|
|
115
|
+
$this->checkPositiveResult($result, 'FOO', 'bar baz');
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
public function testExportParseFail()
|
|
119
|
+
{
|
|
120
|
+
$result = EntryParser::parse('export "FOO="bar baz"');
|
|
121
|
+
$this->checkErrorResult($result, 'Encountered an invalid name at ["FOO].');
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
public function testClosingSlashParse()
|
|
125
|
+
{
|
|
126
|
+
$result = EntryParser::parse('SPVAR5="test some escaped characters like a quote \\" or maybe a backslash \\\\" # not escaped');
|
|
127
|
+
$this->checkPositiveResult($result, 'SPVAR5', 'test some escaped characters like a quote " or maybe a backslash \\');
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
public function testParseInvalidSpaces()
|
|
131
|
+
{
|
|
132
|
+
$result = EntryParser::parse('FOO=bar baz');
|
|
133
|
+
$this->checkErrorResult($result, 'Encountered unexpected whitespace at [bar baz].');
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
public function testParseStrayEquals()
|
|
137
|
+
{
|
|
138
|
+
$result = EntryParser::parse('=');
|
|
139
|
+
$this->checkErrorResult($result, 'Encountered an unexpected equals at [=].');
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
public function testParseInvalidName()
|
|
143
|
+
{
|
|
144
|
+
$result = EntryParser::parse('FOO_ASD!=BAZ');
|
|
145
|
+
$this->checkErrorResult($result, 'Encountered an invalid name at [FOO_ASD!].');
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
public function testParserEscapingDouble()
|
|
149
|
+
{
|
|
150
|
+
$result = EntryParser::parse('FOO_BAD="iiiiviiiixiiiiviiii\\a"');
|
|
151
|
+
$this->checkErrorResult($result, 'Encountered an unexpected escape sequence at ["iiiiviiiixiiiiviiii\a"].');
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
public function testParserEscapingSingle()
|
|
155
|
+
{
|
|
156
|
+
$result = EntryParser::parse('FOO_BAD=\'iiiiviiiixiiiiviiii\\a\'');
|
|
157
|
+
$this->checkPositiveResult($result, 'FOO_BAD', 'iiiiviiiixiiiiviiii\\a');
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
public function testParserMissingClosingSingleQuote()
|
|
161
|
+
{
|
|
162
|
+
$result = EntryParser::parse('TEST=\'erert');
|
|
163
|
+
$this->checkErrorResult($result, 'Encountered a missing closing quote at [\'erert].');
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
public function testParserMissingClosingDoubleQuote()
|
|
167
|
+
{
|
|
168
|
+
$result = EntryParser::parse('TEST="erert');
|
|
169
|
+
$this->checkErrorResult($result, 'Encountered a missing closing quote at ["erert].');
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
public function testParserMissingClosingQuotes()
|
|
173
|
+
{
|
|
174
|
+
$result = EntryParser::parse("TEST=\"erert\nTEST='erert\n");
|
|
175
|
+
$this->checkErrorResult($result, 'Encountered a missing closing quote at ["erert].');
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
public function testParserClosingQuoteWithEscape()
|
|
179
|
+
{
|
|
180
|
+
$result = EntryParser::parse('TEST="\\');
|
|
181
|
+
$this->checkErrorResult($result, 'Encountered a missing closing quote at ["\\].');
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
/**
|
|
185
|
+
* @param \GrahamCampbell\ResultType\Result<\Dotenv\Parser\Entry,string> $result
|
|
186
|
+
* @param string $name
|
|
187
|
+
* @param string $chars
|
|
188
|
+
* @param int[] $vars
|
|
189
|
+
*
|
|
190
|
+
* @return void
|
|
191
|
+
*/
|
|
192
|
+
private function checkPositiveResult(Result $result, string $name, string $chars, array $vars = [])
|
|
193
|
+
{
|
|
194
|
+
self::assertTrue($result->success()->isDefined());
|
|
195
|
+
|
|
196
|
+
$entry = $result->success()->get();
|
|
197
|
+
self::assertInstanceOf(Entry::class, $entry);
|
|
198
|
+
self::assertSame($name, $entry->getName());
|
|
199
|
+
self::assertTrue($entry->getValue()->isDefined());
|
|
200
|
+
|
|
201
|
+
$value = $entry->getValue()->get();
|
|
202
|
+
self::assertInstanceOf(Value::class, $value);
|
|
203
|
+
self::assertSame($chars, $value->getChars());
|
|
204
|
+
self::assertSame($vars, $value->getVars());
|
|
205
|
+
}
|
|
206
|
+
|
|
207
|
+
/**
|
|
208
|
+
* @param \GrahamCampbell\ResultType\Result<\Dotenv\Parser\Entry,string> $result
|
|
209
|
+
* @param string $name
|
|
210
|
+
*
|
|
211
|
+
* @return void
|
|
212
|
+
*/
|
|
213
|
+
private function checkEmptyResult(Result $result, string $name)
|
|
214
|
+
{
|
|
215
|
+
self::assertTrue($result->success()->isDefined());
|
|
216
|
+
|
|
217
|
+
$entry = $result->success()->get();
|
|
218
|
+
self::assertInstanceOf(Entry::class, $entry);
|
|
219
|
+
self::assertSame('FOO', $entry->getName());
|
|
220
|
+
self::assertFalse($entry->getValue()->isDefined());
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
/**
|
|
224
|
+
* @param \GrahamCampbell\ResultType\Result<\Dotenv\Parser\Entry,string> $result
|
|
225
|
+
* @param string $error
|
|
226
|
+
*
|
|
227
|
+
* @return void
|
|
228
|
+
*/
|
|
229
|
+
private function checkErrorResult(Result $result, string $error)
|
|
230
|
+
{
|
|
231
|
+
self::assertTrue($result->error()->isDefined());
|
|
232
|
+
self::assertSame($error, $result->error()->get());
|
|
233
|
+
}
|
|
234
|
+
}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
|
|
3
|
+
declare(strict_types=1);
|
|
4
|
+
|
|
5
|
+
namespace Dotenv\Tests\Parser;
|
|
6
|
+
|
|
7
|
+
use Dotenv\Parser\Lexer;
|
|
8
|
+
use PHPUnit\Framework\TestCase;
|
|
9
|
+
|
|
10
|
+
final class LexerTest extends TestCase
|
|
11
|
+
{
|
|
12
|
+
/**
|
|
13
|
+
* @return array{string,string[]}[]
|
|
14
|
+
*/
|
|
15
|
+
public static function provideLexCases()
|
|
16
|
+
{
|
|
17
|
+
return [
|
|
18
|
+
['', []],
|
|
19
|
+
['FOO', ['FOO']],
|
|
20
|
+
['FOO bar', ['FOO', ' ', 'bar']],
|
|
21
|
+
['FOO\\n()ab', ['FOO', '\\', 'n()ab']],
|
|
22
|
+
["FOO\n\n A", ['FOO', "\n\n", ' ', 'A']],
|
|
23
|
+
['"VA=L"', ['"', 'VA=L', '"']],
|
|
24
|
+
['\' \'', ['\'', ' ', '\'']],
|
|
25
|
+
];
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* @dataProvider provideLexCases
|
|
30
|
+
*
|
|
31
|
+
* @param string $input
|
|
32
|
+
* @param string[] $output
|
|
33
|
+
*
|
|
34
|
+
* @return void
|
|
35
|
+
*/
|
|
36
|
+
public function testLex(string $input, array $output)
|
|
37
|
+
{
|
|
38
|
+
self::assertSame($output, \iterator_to_array(Lexer::lex($input)));
|
|
39
|
+
}
|
|
40
|
+
}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
|
|
3
|
+
declare(strict_types=1);
|
|
4
|
+
|
|
5
|
+
namespace Dotenv\Tests\Parser;
|
|
6
|
+
|
|
7
|
+
use Dotenv\Parser\Lines;
|
|
8
|
+
use Dotenv\Util\Regex;
|
|
9
|
+
use PHPUnit\Framework\TestCase;
|
|
10
|
+
|
|
11
|
+
final class LinesTest extends TestCase
|
|
12
|
+
{
|
|
13
|
+
public function testProcessBasic()
|
|
14
|
+
{
|
|
15
|
+
$content = \file_get_contents(\dirname(\dirname(__DIR__)).'/fixtures/env/assertions.env');
|
|
16
|
+
self::assertIsString($content);
|
|
17
|
+
$result = Regex::split("/(\r\n|\n|\r)/", $content);
|
|
18
|
+
self::assertTrue($result->success()->isDefined());
|
|
19
|
+
|
|
20
|
+
$expected = [
|
|
21
|
+
'ASSERTVAR1=val1',
|
|
22
|
+
'ASSERTVAR2=""',
|
|
23
|
+
'ASSERTVAR3="val3 "',
|
|
24
|
+
'ASSERTVAR4="0" # empty looking value',
|
|
25
|
+
'ASSERTVAR5="#foo"',
|
|
26
|
+
"ASSERTVAR6=\"val1\nval2\"",
|
|
27
|
+
"ASSERTVAR7=\"\nval3\" #",
|
|
28
|
+
"ASSERTVAR8=\"val3\n\"",
|
|
29
|
+
"ASSERTVAR9=\"\n\n\"",
|
|
30
|
+
];
|
|
31
|
+
|
|
32
|
+
self::assertSame($expected, Lines::process($result->success()->get()));
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
public function testProcessQuotes()
|
|
36
|
+
{
|
|
37
|
+
$content = \file_get_contents(\dirname(\dirname(__DIR__)).'/fixtures/env/multiline.env');
|
|
38
|
+
self::assertIsString($content);
|
|
39
|
+
$result = Regex::split("/(\r\n|\n|\r)/", $content);
|
|
40
|
+
self::assertTrue($result->success()->isDefined());
|
|
41
|
+
|
|
42
|
+
$expected = [
|
|
43
|
+
"TEST=\"test\n test\\\"test\\\"\n test\"",
|
|
44
|
+
'TEST_ND="test\\ntest"',
|
|
45
|
+
'TEST_NS=\'test\\ntest\'',
|
|
46
|
+
'TEST_EQD="https://vision.googleapis.com/v1/images:annotate?key="',
|
|
47
|
+
'TEST_EQS=\'https://vision.googleapis.com/v1/images:annotate?key=\'',
|
|
48
|
+
"BASE64_ENCODED_MULTILINE=\"qS1zCzMVVUJWQShokv6YVYi+ruKSC/bHV7GmEiyVkLaBWJHNVHCHsgTksEBsy8wJ\nuwycAvR07ZyOJJed4XTRMKnKp1/v+6UATpWzkIjZXytK+pD+XlZimUHTx3uiDcmU\njhQX1wWSxHDqrSWxeIJiTD+BuUyId8FzmXQ3TcBydJ474tmOU2F492ubk3LAiZ18\nmhiRGoshXAOSbS/P3+RZi4bDeNE/No4=\"",
|
|
49
|
+
];
|
|
50
|
+
|
|
51
|
+
self::assertSame($expected, Lines::process($result->success()->get()));
|
|
52
|
+
}
|
|
53
|
+
}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
|
|
3
|
+
declare(strict_types=1);
|
|
4
|
+
|
|
5
|
+
namespace Dotenv\Tests\Parser;
|
|
6
|
+
|
|
7
|
+
use Dotenv\Exception\InvalidFileException;
|
|
8
|
+
use Dotenv\Parser\Entry;
|
|
9
|
+
use Dotenv\Parser\Parser;
|
|
10
|
+
use Dotenv\Parser\ParserInterface;
|
|
11
|
+
use Dotenv\Parser\Value;
|
|
12
|
+
use PHPUnit\Framework\TestCase;
|
|
13
|
+
|
|
14
|
+
final class ParserTest extends TestCase
|
|
15
|
+
{
|
|
16
|
+
public function testParserInstanceOf()
|
|
17
|
+
{
|
|
18
|
+
self::assertInstanceOf(ParserInterface::class, new Parser());
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
public function testFullParse()
|
|
22
|
+
{
|
|
23
|
+
$result = (new Parser())->parse("FOO=BAR\nFOO\nFOO=\"BAR \n\"\nFOO=\"\\n\"");
|
|
24
|
+
|
|
25
|
+
self::assertIsArray($result);
|
|
26
|
+
self::assertCount(4, $result);
|
|
27
|
+
|
|
28
|
+
$this->checkPositiveEntry($result[0], 'FOO', 'BAR');
|
|
29
|
+
$this->checkEmptyEntry($result[1], 'FOO');
|
|
30
|
+
$this->checkPositiveEntry($result[2], 'FOO', "BAR \n");
|
|
31
|
+
$this->checkPositiveEntry($result[3], 'FOO', "\n");
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
public function testBadEscapeParse()
|
|
35
|
+
{
|
|
36
|
+
$this->expectException(InvalidFileException::class);
|
|
37
|
+
$this->expectExceptionMessage('Failed to parse dotenv file. Encountered an unexpected escape sequence at ["\q"].');
|
|
38
|
+
|
|
39
|
+
(new Parser())->parse('FOO="\q"');
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
public function testParseInvalidSpaces()
|
|
43
|
+
{
|
|
44
|
+
$this->expectException(InvalidFileException::class);
|
|
45
|
+
$this->expectExceptionMessage('Failed to parse dotenv file. Encountered unexpected whitespace at [bar baz].');
|
|
46
|
+
|
|
47
|
+
(new Parser())->parse("FOO=bar baz\n");
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
public function testParseStrayEquals()
|
|
51
|
+
{
|
|
52
|
+
$this->expectException(InvalidFileException::class);
|
|
53
|
+
$this->expectExceptionMessage('Failed to parse dotenv file. Encountered an unexpected equals at [=].');
|
|
54
|
+
|
|
55
|
+
(new Parser())->parse("=\n");
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
public function testParseInvalidName()
|
|
59
|
+
{
|
|
60
|
+
$this->expectException(InvalidFileException::class);
|
|
61
|
+
$this->expectExceptionMessage('Failed to parse dotenv file. Encountered an invalid name at [FOO_ASD!].');
|
|
62
|
+
|
|
63
|
+
(new Parser())->parse('FOO_ASD!=BAZ');
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
/**
|
|
67
|
+
* @param \Dotenv\Parser\Entry $entry
|
|
68
|
+
* @param string $name
|
|
69
|
+
* @param string $chars
|
|
70
|
+
* @param int[] $vars
|
|
71
|
+
*
|
|
72
|
+
* @return void
|
|
73
|
+
*/
|
|
74
|
+
private function checkPositiveEntry(Entry $entry, string $name, string $chars, array $vars = [])
|
|
75
|
+
{
|
|
76
|
+
self::assertInstanceOf(Entry::class, $entry);
|
|
77
|
+
self::assertSame($name, $entry->getName());
|
|
78
|
+
self::assertTrue($entry->getValue()->isDefined());
|
|
79
|
+
|
|
80
|
+
$value = $entry->getValue()->get();
|
|
81
|
+
self::assertInstanceOf(Value::class, $value);
|
|
82
|
+
self::assertSame($chars, $value->getChars());
|
|
83
|
+
self::assertSame($vars, $value->getVars());
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
/**
|
|
87
|
+
* @param \Dotenv\Parser\Entry $entry
|
|
88
|
+
* @param string $name
|
|
89
|
+
*
|
|
90
|
+
* @return void
|
|
91
|
+
*/
|
|
92
|
+
private function checkEmptyEntry(Entry $entry, string $name)
|
|
93
|
+
{
|
|
94
|
+
self::assertInstanceOf(Entry::class, $entry);
|
|
95
|
+
self::assertSame('FOO', $entry->getName());
|
|
96
|
+
self::assertFalse($entry->getValue()->isDefined());
|
|
97
|
+
}
|
|
98
|
+
}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
|
|
3
|
+
declare(strict_types=1);
|
|
4
|
+
|
|
5
|
+
namespace Dotenv\Tests\Repository\Adapter;
|
|
6
|
+
|
|
7
|
+
use Dotenv\Repository\Adapter\ArrayAdapter;
|
|
8
|
+
use PHPUnit\Framework\TestCase;
|
|
9
|
+
|
|
10
|
+
final class ArrayAdapterTest extends TestCase
|
|
11
|
+
{
|
|
12
|
+
public function testGoodRead()
|
|
13
|
+
{
|
|
14
|
+
$adapter = self::createAdapter();
|
|
15
|
+
$adapter->write('CONST_TEST', 'foo bar baz');
|
|
16
|
+
$value = $adapter->read('CONST_TEST');
|
|
17
|
+
self::assertTrue($value->isDefined());
|
|
18
|
+
self::assertSame('foo bar baz', $value->get());
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
public function testUndefinedRead()
|
|
22
|
+
{
|
|
23
|
+
$adapter = self::createAdapter();
|
|
24
|
+
unset($_ENV['CONST_TEST']);
|
|
25
|
+
$value = $adapter->read('CONST_TEST');
|
|
26
|
+
self::assertFalse($value->isDefined());
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
public function testGoodWrite()
|
|
30
|
+
{
|
|
31
|
+
$adapter = self::createAdapter();
|
|
32
|
+
self::assertTrue($adapter->write('CONST_TEST', 'foo'));
|
|
33
|
+
self::assertSame('foo', $adapter->read('CONST_TEST')->get());
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
public function testEmptyWrite()
|
|
37
|
+
{
|
|
38
|
+
$adapter = self::createAdapter();
|
|
39
|
+
self::assertTrue($adapter->write('CONST_TEST', ''));
|
|
40
|
+
self::assertSame('', $adapter->read('CONST_TEST')->get());
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
public function testGoodDelete()
|
|
44
|
+
{
|
|
45
|
+
$adapter = self::createAdapter();
|
|
46
|
+
self::assertTrue($adapter->delete('CONST_TEST'));
|
|
47
|
+
self::assertFalse($adapter->read('CONST_TEST')->isDefined());
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* @return \Dotenv\Repository\Adapter\AdapterInterface
|
|
52
|
+
*/
|
|
53
|
+
private static function createAdapter()
|
|
54
|
+
{
|
|
55
|
+
return ArrayAdapter::create()->get();
|
|
56
|
+
}
|
|
57
|
+
}
|
package/src/api/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/Adapter/EnvConstAdapterTest.php
ADDED
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
|
|
3
|
+
declare(strict_types=1);
|
|
4
|
+
|
|
5
|
+
namespace Dotenv\Tests\Repository\Adapter;
|
|
6
|
+
|
|
7
|
+
use Dotenv\Repository\Adapter\EnvConstAdapter;
|
|
8
|
+
use PHPUnit\Framework\TestCase;
|
|
9
|
+
|
|
10
|
+
final class EnvConstAdapterTest extends TestCase
|
|
11
|
+
{
|
|
12
|
+
public function testGoodRead()
|
|
13
|
+
{
|
|
14
|
+
$_ENV['CONST_TEST'] = 'foo bar baz';
|
|
15
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
16
|
+
self::assertTrue($value->isDefined());
|
|
17
|
+
self::assertSame('foo bar baz', $value->get());
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
public function testFalseRead()
|
|
21
|
+
{
|
|
22
|
+
$_ENV['CONST_TEST'] = false;
|
|
23
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
24
|
+
self::assertTrue($value->isDefined());
|
|
25
|
+
self::assertSame('false', $value->get());
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
public function testTrueRead()
|
|
29
|
+
{
|
|
30
|
+
$_ENV['CONST_TEST'] = true;
|
|
31
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
32
|
+
self::assertTrue($value->isDefined());
|
|
33
|
+
self::assertSame('true', $value->get());
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
public function testBadTypeRead()
|
|
37
|
+
{
|
|
38
|
+
$_ENV['CONST_TEST'] = [123];
|
|
39
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
40
|
+
self::assertFalse($value->isDefined());
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
public function testUndefinedRead()
|
|
44
|
+
{
|
|
45
|
+
unset($_ENV['CONST_TEST']);
|
|
46
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
47
|
+
self::assertFalse($value->isDefined());
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
public function testGoodWrite()
|
|
51
|
+
{
|
|
52
|
+
self::assertTrue(self::createAdapter()->write('CONST_TEST', 'foo'));
|
|
53
|
+
self::assertSame('foo', $_ENV['CONST_TEST']);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
public function testEmptyWrite()
|
|
57
|
+
{
|
|
58
|
+
self::assertTrue(self::createAdapter()->write('CONST_TEST', ''));
|
|
59
|
+
self::assertSame('', $_ENV['CONST_TEST']);
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
public function testGoodDelete()
|
|
63
|
+
{
|
|
64
|
+
self::assertTrue(self::createAdapter()->delete('CONST_TEST'));
|
|
65
|
+
self::assertFalse(isset($_ENV['CONST_TEST']));
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
/**
|
|
69
|
+
* @return \Dotenv\Repository\Adapter\AdapterInterface
|
|
70
|
+
*/
|
|
71
|
+
private static function createAdapter()
|
|
72
|
+
{
|
|
73
|
+
return EnvConstAdapter::create()->get();
|
|
74
|
+
}
|
|
75
|
+
}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
|
|
3
|
+
declare(strict_types=1);
|
|
4
|
+
|
|
5
|
+
namespace Dotenv\Tests\Repository\Adapter;
|
|
6
|
+
|
|
7
|
+
use Dotenv\Repository\Adapter\PutenvAdapter;
|
|
8
|
+
use PHPUnit\Framework\TestCase;
|
|
9
|
+
|
|
10
|
+
final class PutenvAdapterTest extends TestCase
|
|
11
|
+
{
|
|
12
|
+
public function testGoodRead()
|
|
13
|
+
{
|
|
14
|
+
\putenv('CONST_TEST=foo bar baz');
|
|
15
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
16
|
+
self::assertTrue($value->isDefined());
|
|
17
|
+
self::assertSame('foo bar baz', $value->get());
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
public function testUndefinedRead()
|
|
21
|
+
{
|
|
22
|
+
\putenv('CONST_TEST');
|
|
23
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
24
|
+
self::assertFalse($value->isDefined());
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
public function testGoodWrite()
|
|
28
|
+
{
|
|
29
|
+
self::assertTrue(self::createAdapter()->write('CONST_TEST', 'foo'));
|
|
30
|
+
self::assertSame('foo', \getenv('CONST_TEST'));
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
public function testEmptyWrite()
|
|
34
|
+
{
|
|
35
|
+
self::assertTrue(self::createAdapter()->write('CONST_TEST', ''));
|
|
36
|
+
self::assertSame('', \getenv('CONST_TEST'));
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
public function testGoodDelete()
|
|
40
|
+
{
|
|
41
|
+
self::assertTrue(self::createAdapter()->delete('CONST_TEST'));
|
|
42
|
+
self::assertFalse(\getenv('CONST_TEST'));
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* @return \Dotenv\Repository\Adapter\AdapterInterface
|
|
47
|
+
*/
|
|
48
|
+
private static function createAdapter()
|
|
49
|
+
{
|
|
50
|
+
return PutenvAdapter::create()->get();
|
|
51
|
+
}
|
|
52
|
+
}
|
package/src/api/vendor/vlucas/phpdotenv/tests/Dotenv/Repository/Adapter/ServerConstAdapterTest.php
ADDED
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
<?php
|
|
2
|
+
|
|
3
|
+
declare(strict_types=1);
|
|
4
|
+
|
|
5
|
+
namespace Dotenv\Tests\Repository\Adapter;
|
|
6
|
+
|
|
7
|
+
use Dotenv\Repository\Adapter\ServerConstAdapter;
|
|
8
|
+
use PHPUnit\Framework\TestCase;
|
|
9
|
+
|
|
10
|
+
final class ServerConstAdapterTest extends TestCase
|
|
11
|
+
{
|
|
12
|
+
public function testGoodRead()
|
|
13
|
+
{
|
|
14
|
+
$_SERVER['CONST_TEST'] = 'foo bar baz';
|
|
15
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
16
|
+
self::assertTrue($value->isDefined());
|
|
17
|
+
self::assertSame('foo bar baz', $value->get());
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
public function testFalseRead()
|
|
21
|
+
{
|
|
22
|
+
$_SERVER['CONST_TEST'] = false;
|
|
23
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
24
|
+
self::assertTrue($value->isDefined());
|
|
25
|
+
self::assertSame('false', $value->get());
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
public function testTrueRead()
|
|
29
|
+
{
|
|
30
|
+
$_SERVER['CONST_TEST'] = true;
|
|
31
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
32
|
+
self::assertTrue($value->isDefined());
|
|
33
|
+
self::assertSame('true', $value->get());
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
public function testBadTypeRead()
|
|
37
|
+
{
|
|
38
|
+
$_SERVER['CONST_TEST'] = [123];
|
|
39
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
40
|
+
self::assertFalse($value->isDefined());
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
public function testUndefinedRead()
|
|
44
|
+
{
|
|
45
|
+
unset($_SERVER['CONST_TEST']);
|
|
46
|
+
$value = self::createAdapter()->read('CONST_TEST');
|
|
47
|
+
self::assertFalse($value->isDefined());
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
public function testGoodWrite()
|
|
51
|
+
{
|
|
52
|
+
self::assertTrue(self::createAdapter()->write('CONST_TEST', 'foo'));
|
|
53
|
+
self::assertSame('foo', $_SERVER['CONST_TEST']);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
public function testEmptyWrite()
|
|
57
|
+
{
|
|
58
|
+
self::assertTrue(self::createAdapter()->write('CONST_TEST', ''));
|
|
59
|
+
self::assertSame('', $_SERVER['CONST_TEST']);
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
public function testGoodDelete()
|
|
63
|
+
{
|
|
64
|
+
self::assertTrue(self::createAdapter()->delete('CONST_TEST'));
|
|
65
|
+
self::assertFalse(isset($_SERVER['CONST_TEST']));
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
/**
|
|
69
|
+
* @return \Dotenv\Repository\Adapter\AdapterInterface
|
|
70
|
+
*/
|
|
71
|
+
private static function createAdapter()
|
|
72
|
+
{
|
|
73
|
+
return ServerConstAdapter::create()->get();
|
|
74
|
+
}
|
|
75
|
+
}
|