summaryrefslogtreecommitdiff
path: root/tests/Feature
diff options
context:
space:
mode:
Diffstat (limited to 'tests/Feature')
-rw-r--r--tests/Feature/AssetsTest.php78
1 files changed, 78 insertions, 0 deletions
diff --git a/tests/Feature/AssetsTest.php b/tests/Feature/AssetsTest.php
new file mode 100644
index 0000000..887142c
--- /dev/null
+++ b/tests/Feature/AssetsTest.php
@@ -0,0 +1,78 @@
+<?php
+
+use Lightscale\LaralightAssets\Assets;
+use Lightscale\LaralightAssets\Manifest;
+
+it('instantiates', function() {
+ new Assets();
+})->throwsNoExceptions();
+
+it('instantiates from container', function() {
+ app(Assets::class);
+})->throwsNoExceptions();
+
+it('is singleton', function() {
+ expect(app(Assets::class))->toBe(app(Assets::class));
+});
+
+it('adds manifests', function() {
+ app(Assets::class)->addManifest(
+ 'main',
+ new Manifest(
+ public_path('dist/manifest.json'),
+ '/dist',
+ ),
+ isDefault: true,
+ );
+})->throwsNoExceptions();
+
+it('registers manifests', function() {
+ app(Assets::class)->registerManifest(
+ 'main', public_path('dist/manifest.json'), '/dist', isDefault: true,
+ );
+})->throwsNoExceptions();
+
+it('gets manifests', function() {
+ $assets = app(Assets::class);
+ $assets->registerManifest(
+ 'main', public_path('dist/manifest.json'), '/dist', isDefault: true,
+ );
+
+ expect($assets->getManifests())
+ ->toHaveLength(1)
+ ->toContainOnlyInstancesOf(Manifest::class);
+});
+
+it('gets manifest', function() {
+ $assets = app(Assets::class);
+ $manifest = new Manifest(
+ public_path('dist/manifest.json'),
+ '/dist',
+ );
+ $name = 'main';
+ $assets->addManifest($name, $manifest, true);
+
+ expect($assets->getManifest($name))->toBe($manifest);
+});
+
+it('gets default manifest', function() {
+ $assets = app(Assets::class);
+ $manifest = new Manifest(
+ public_path('dist/manifest.json'),
+ '/dist',
+ );
+ $name = 'main';
+ $assets->addManifest($name, $manifest, true);
+
+ expect($assets->getDefaultManifest())->toBe($manifest);
+});
+
+it('throws exception missing manifest', function() {
+ $assets = app(Assets::class);
+ $assets->getManifest('main');
+})->throws(Exception::class);
+
+it('throws exception without default', function() {
+ $assets = app(Assets::class);
+ $assets->getDefaultManifest();
+})->throws(Error::class);