Laravel phpunit test maatwebsite/excel import



我创建了一个maatwebsite/excel导入例程,我想测试一下。

maatwebsite/excel 测试页面除了伪造它之外没有为我提供任何其他信息。 但是我需要上传我真正的 excel 文件,因为我想验证 excel 文件中的数据是否正确处理。

这是我的上传输入字段和相应的按钮,用于点击端点/import

<form action="/import" method="post" enctype="multipart/form-data">
@csrf
<div class="form-group">
<input type="file" class="form-control-file file-path" name="fileToUpload">
</div>
<button type="submit" class="btn btn-primary">Import File</button>
</form>

在视图的控制器端,将处理和导入上传的文件。

...
public function store(Request $request) {
$request->validate([
'fileToUpload' => 'required|file|max:4096|mimes:xls,xlsx',
]);
// start the import
Excel::import(new SheetNavigator, request()->file('fileToUpload'));
...

需要导入的文件位于我的测试环境中:

/tests
/files
/myexcel.xlsx
public function test_user_can_import_file() {
Excel::fake();
$datafile = new UploadedFile(
base_path('tests/files/myfile.xlsx'),
'myfile.xlsx',
'xlsx',
13071,
true);
$res = $this->post('/import', [
'fileToUpload' => $datafile
]);
// asserting, that everything works..
}

我需要一个测试来验证上传是否成功以及导入例程是否已触发。 我尝试了一切,从伪造任何东西到使用存储。

我感谢任何形式的帮助,谢谢!

克里斯

一般来说,理想的方法是模拟Excel类,然后检查是否已使用给定文件调用import。尽管这似乎是一个静态调用,但它实际上是一个外观调用,因此您可以将其替换为模拟调用。实际上,它似乎自己提供了此功能:

public function testThatItImportsTheUploadedFile() {
$file = UploadedFile::fake()->create('myexcel.xlsx');
Excel::fake();
$this->post('/import', [
'fileToUpload' => $file
]);
Excel::assertImported('myexcel.xlsx');
}

注意:这将验证端点是否按预期工作,前提是文件已上传,并且Excel::import将按预期工作。

如果你想用你的真实文件进行测试,你可以创建一个新的UploadedFile实例(链接symfony基类,因为那是构造函数所在的地方(。

$file = new UploadedFile(
base_path('tests/files/myfile.xlsx'),
'myfile.xlsx',
'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
null,
true
);

最新更新