chore: make contentTracing.stopRecording() failure clearer (#38488)

chore: make contentTracing.stopRecording() failure clearer
This commit is contained in:
Shelley Vohr 2023-05-31 15:54:41 +02:00 committed by GitHub
parent 115d37477e
commit 663497dc6b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 10 additions and 5 deletions

View file

@ -77,15 +77,20 @@ void StopTracing(gin_helper::Promise<base::FilePath> promise,
}
},
std::move(promise), *file_path);
if (file_path) {
auto* instance = TracingController::GetInstance();
if (!instance->IsTracing()) {
std::move(resolve_or_reject)
.Run(absl::make_optional(
"Failed to stop tracing - no trace in progress"));
} else if (file_path) {
auto split_callback = base::SplitOnceCallback(std::move(resolve_or_reject));
auto endpoint = TracingController::CreateFileEndpoint(
*file_path,
base::BindOnce(std::move(split_callback.first), absl::nullopt));
if (!TracingController::GetInstance()->StopTracing(endpoint)) {
if (!instance->StopTracing(endpoint)) {
std::move(split_callback.second)
.Run(absl::make_optional(
"Failed to stop tracing (was a trace in progress?)"));
.Run(absl::make_optional("Failed to stop tracing"));
}
} else {
std::move(resolve_or_reject)

View file

@ -114,7 +114,7 @@ ifdescribe(!(['arm', 'arm64', 'ia32'].includes(process.arch)))('contentTracing',
});
it('rejects if no trace is happening', async () => {
await expect(contentTracing.stopRecording()).to.be.rejected();
await expect(contentTracing.stopRecording()).to.be.rejectedWith('Failed to stop tracing - no trace in progress');
});
});