summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTristan Cacqueray <tdecacqu@redhat.com>2021-02-13 01:35:46 +0000
committerTristan Cacqueray <tdecacqu@redhat.com>2021-02-13 14:46:07 +0000
commit33b40dcb6b3100169112d1e05bc04e8569267538 (patch)
treef6bcaa26f45470d0a883419864fba8fa3dcf0448
parenta397a9a02753a96fe5a04f2b89b7896a2bc8b9a4 (diff)
downloadzuul-33b40dcb6b3100169112d1e05bc04e8569267538.tar.gz
web: add benchmark test for build output
This change measures the render time of the BuildOutput component. Change-Id: I47979443781f0150f8f203c857847801d54a7385
-rw-r--r--web/src/containers/build/BuildOutput.test.jsx38
1 files changed, 38 insertions, 0 deletions
diff --git a/web/src/containers/build/BuildOutput.test.jsx b/web/src/containers/build/BuildOutput.test.jsx
new file mode 100644
index 000000000..c76236a2e
--- /dev/null
+++ b/web/src/containers/build/BuildOutput.test.jsx
@@ -0,0 +1,38 @@
+// Copyright 2021 Red Hat, Inc
+//
+// Licensed under the Apache License, Version 2.0 (the "License"); you may
+// not use this file except in compliance with the License. You may obtain
+// a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+// License for the specific language governing permissions and limitations
+// under the License.
+
+import React from 'react'
+import ReactDOM from 'react-dom'
+import BuildOutput from './BuildOutput'
+
+const fakeOutput = (width, height) => ({
+ test: {
+ failed: [
+ {
+ zuul_log_id: 'fake',
+ stderr_lines: Array(height).fill('x'.repeat(width))
+ },
+ ],
+ },
+})
+
+it('BuildOutput renders big task', () => {
+ const div = document.createElement('div')
+ const output = fakeOutput(512, 1024)
+ const begin = performance.now()
+ ReactDOM.render(<BuildOutput output={output} />, div, () => {
+ const end = performance.now()
+ console.log('Render took ' + (end - begin) + ' milliseconds.')
+ })
+})