mirror of
https://github.com/archtechx/tenancy.git
synced 2025-12-12 12:44:02 +00:00
[4.x] Fix ViteBundler not affecting Vite static calls (#1389)
* Fix ViteBundler not affecting Vite static calls Replace custom Vite class override with Vite::createAssetPathsUsing() to ensure ViteBundler works for both container and static usage when asset_helper_override is enabled. Fixes #1388 * Remove redundant logic from tests * Simplify test further * Re-add file creation logic --------- Co-authored-by: Samuel Štancl <samuel@archte.ch>
This commit is contained in:
parent
3b42c9e20c
commit
99d854ed8e
3 changed files with 35 additions and 41 deletions
|
|
@ -5,8 +5,8 @@ declare(strict_types=1);
|
||||||
namespace Stancl\Tenancy\Features;
|
namespace Stancl\Tenancy\Features;
|
||||||
|
|
||||||
use Illuminate\Foundation\Application;
|
use Illuminate\Foundation\Application;
|
||||||
|
use Illuminate\Support\Facades\Vite;
|
||||||
use Stancl\Tenancy\Contracts\Feature;
|
use Stancl\Tenancy\Contracts\Feature;
|
||||||
use Stancl\Tenancy\Overrides\Vite;
|
|
||||||
use Stancl\Tenancy\Tenancy;
|
use Stancl\Tenancy\Tenancy;
|
||||||
|
|
||||||
class ViteBundler implements Feature
|
class ViteBundler implements Feature
|
||||||
|
|
@ -21,6 +21,8 @@ class ViteBundler implements Feature
|
||||||
|
|
||||||
public function bootstrap(Tenancy $tenancy): void
|
public function bootstrap(Tenancy $tenancy): void
|
||||||
{
|
{
|
||||||
$this->app->singleton(\Illuminate\Foundation\Vite::class, Vite::class);
|
Vite::createAssetPathsUsing(function ($path, $secure = null) {
|
||||||
|
return global_asset($path);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,22 +0,0 @@
|
||||||
<?php
|
|
||||||
|
|
||||||
declare(strict_types=1);
|
|
||||||
|
|
||||||
namespace Stancl\Tenancy\Overrides;
|
|
||||||
|
|
||||||
use Illuminate\Foundation\Vite as BaseVite;
|
|
||||||
|
|
||||||
class Vite extends BaseVite
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Generate an asset path for the application.
|
|
||||||
*
|
|
||||||
* @param string $path
|
|
||||||
* @param bool|null $secure
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
protected function assetPath($path, $secure = null)
|
|
||||||
{
|
|
||||||
return global_asset($path);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -3,27 +3,41 @@
|
||||||
declare(strict_types=1);
|
declare(strict_types=1);
|
||||||
|
|
||||||
use Illuminate\Foundation\Vite;
|
use Illuminate\Foundation\Vite;
|
||||||
use Stancl\Tenancy\Tests\Etc\Tenant;
|
use Illuminate\Support\Facades\File;
|
||||||
use Stancl\Tenancy\Overrides\Vite as StanclVite;
|
use Stancl\Tenancy\Bootstrappers\FilesystemTenancyBootstrapper;
|
||||||
use Stancl\Tenancy\Features\ViteBundler;
|
use Stancl\Tenancy\Features\ViteBundler;
|
||||||
|
use Stancl\Tenancy\Tests\Etc\Tenant;
|
||||||
|
|
||||||
test('vite helper uses our custom class', function() {
|
use function Stancl\Tenancy\Tests\withBootstrapping;
|
||||||
$vite = app(Vite::class);
|
|
||||||
|
|
||||||
expect($vite)->toBeInstanceOf(Vite::class);
|
|
||||||
expect($vite)->not()->toBeInstanceOf(StanclVite::class);
|
|
||||||
|
|
||||||
|
beforeEach(function () {
|
||||||
config([
|
config([
|
||||||
'tenancy.features' => [ViteBundler::class],
|
'tenancy.filesystem.asset_helper_override' => true,
|
||||||
|
'tenancy.bootstrappers' => [FilesystemTenancyBootstrapper::class],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
$tenant = Tenant::create();
|
File::ensureDirectoryExists(dirname($manifestPath = public_path('build/manifest.json')));
|
||||||
|
File::put($manifestPath, json_encode([
|
||||||
tenancy()->initialize($tenant);
|
'foo' => [
|
||||||
|
'file' => 'assets/foo-AbC123.js',
|
||||||
app()->forgetInstance(Vite::class);
|
'src' => 'js/foo.js',
|
||||||
|
],
|
||||||
$vite = app(Vite::class);
|
]));
|
||||||
|
});
|
||||||
expect($vite)->toBeInstanceOf(StanclVite::class);
|
|
||||||
|
test('vite bundler ensures vite assets use global_asset when asset_helper_override is enabled', function () {
|
||||||
|
config(['tenancy.features' => [ViteBundler::class]]);
|
||||||
|
|
||||||
|
withBootstrapping();
|
||||||
|
|
||||||
|
tenancy()->initialize(Tenant::create());
|
||||||
|
|
||||||
|
// Not what we want
|
||||||
|
expect(asset('foo'))->toBe(route('stancl.tenancy.asset', ['path' => 'foo']));
|
||||||
|
|
||||||
|
$viteAssetUrl = app(Vite::class)->asset('foo');
|
||||||
|
$expectedGlobalUrl = global_asset('build/assets/foo-AbC123.js');
|
||||||
|
|
||||||
|
expect($viteAssetUrl)->toBe($expectedGlobalUrl);
|
||||||
|
expect($viteAssetUrl)->toBe('http://localhost/build/assets/foo-AbC123.js');
|
||||||
});
|
});
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue