Tested 2020-12-21 10:46:47 using Chrome 87.0.4280.88. 3 runs and connectivity native.
Metric | Value |
---|---|
Performance Score | 77 |
Total Page Transfer Size | 324.6 KB |
Requests | 33 |
TTFB [median] | 247 ms |
Fully Loaded [median] | 1.045 s |
First Visual Change [median] | 536 ms |
First Contentful Paint (FCP) [median] | 533 ms |
Largest Contentful Paint (LCP) [median] | 533 ms |
Cumulative Layout Shift (CLS) [median] | 0.00 |
Total Blocking Time [median] | 24 ms |
Max Potential FID [median] | 74 ms |
CPU long tasks [median] | 2 |
CPU longest task duration | 160 ms |
Speed Index [median] | 539 ms |
Visual Complete 85% [median] | 536 ms |
Visual Complete 99% [median] | 637 ms |
Last Visual Change [median] | 804 ms |
Metric | min | median | mean | max |
---|---|---|---|---|
Visual Metrics | ||||
SpeedIndex | 438 ms | 539 ms | 534 ms | 625 ms |
FirstVisualChange | 437 ms | 536 ms | 530 ms | 617 ms |
LastVisualChange | 471 ms | 804 ms | 814 ms | 1.166 s |
VisualReadiness | 34 ms | 268 ms | 284 ms | 549 ms |
VisualComplete85 | 437 ms | 536 ms | 530 ms | 617 ms |
VisualComplete95 | 437 ms | 536 ms | 530 ms | 617 ms |
VisualComplete99 | 471 ms | 637 ms | 667 ms | 892 ms |
RUM Metrics | ||||
TTFB | 112 ms | 247 ms | 219 ms | 298 ms |
LCP | 404 ms | 533 ms | 512 ms | 600 ms |
FCP | 404 ms | 533 ms | 512 ms | 600 ms |
firstPaint | 404 ms | 533 ms | 512 ms | 600 ms |
loadEventEnd | 565 ms | 996 ms | 927 ms | 1.220 s |
CLS | 0 | 0 | 0 | 0 |
User Timing | ||||
mwStartup | 447 ms | 517 ms | 510 ms | 567 ms |
CPU | ||||
Total Blocking Time | 16 ms | 24 ms | 35 ms | 64 ms |
Max Potential FID | 66 ms | 74 ms | 80 ms | 101 ms |
CPU long tasks | 2 | 2 | 2 | 3 |
Run 3 SpeedIndex median
Use--filmstrip.showAll
to show all filmstrips.
The coach helps you find performance problems on your web page using web performance best practice rules. And gives you advice on privacy and best practices.
Title | Advice | Score |
---|---|---|
Inline CSS for faster first render (inlineCss) | The page has both inline CSS and CSS requests even though it uses a HTTP/2-ish connection. If you have many users on slow connections, it can be better to only inline the CSS. Run your own tests and check the waterfall graph to see what happens. | 95 |
Description: In the early days of the Internet, inlining CSS was one of the ugliest things you can do. That has changed if you want your page to start rendering fast for your user. Always inline the critical CSS when you use HTTP/1 and HTTP/2 (avoid doing CSS requests that block rendering) and lazy load and cache the rest of the CSS. It is a little more complicated when using HTTP/2. Does your server support HTTP push? Then maybe that can help. Do you have a lot of users on a slow connection and are serving large chunks of HTML? Then it could be better to use the inline technique, becasue some servers always prioritize HTML content over CSS so the user needs to download the HTML first, before the CSS is downloaded. | ||
Avoid CPU Long Tasks (longTasks) | The page has 2 CPU long tasks with the total of 235 ms. However the CPU Long Task is depending on the computer/phones actual CPU speed, so you should measure this on the same type of the device that your user is using. Use Geckoprofiler for Firefox or Chromes tracelog to debug your Long Task. | 60 |
Description: Long CPU tasks locks the thread. To the user this is commonly visible as a "locked up" page where the browser is unable to respond to user input; this is a major source of bad user experience on the web today. However the CPU Long Task is depending on the computer/phones actual CPU speed, so you should measure this on the same type of the device that your user is using. | ||
Offenders:
| ||
Avoid extra requests by setting cache headers (cacheHeaders) | The page has 19 requests that are missing a cache time. Configure a cache time so the browser doesn't need to download them every time. It will save 85.1 kB the next access. | 0 |
Description: The easiest way to make your page fast is to avoid doing requests to the server. Setting a cache header on your server response will tell the browser that it doesn't need to download the asset again during the configured cache time! Always try to set a cache time if the content doesn't change for every request. | ||
Offenders:
| ||
Long cache headers is good (cacheHeadersLong) | The page has 3 requests that have a shorter cache time than 30 days (but still a cache time). | 97 |
Description: Setting a cache header is good. Setting a long cache header (at least 30 days) is even better beacause then it will stay long in the browser cache. But what do you do if that asset change? Rename it and the browser will pick up the new version. | ||
Offenders: | ||
Total JavaScript size shouldn't be too big (javascriptSize) | The total JavaScript transfer size is 200.9 kB and the uncompressed size is 717.8 kB. This is quite large. | 0 |
Description: A lot of JavaScript often means you are downloading more than you need. How complex is the page and what can the user do on the page? Do you use multiple JavaScript frameworks? | ||
Don't use private headers on static content (privateAssets) | The page has 2 requests with private headers. The main page has a private header. It could be right in some cases where the user can be logged in and served specific content. But if your asset is static it should never be private. Make sure that the assets really should be private and only used by one user. Otherwise, make it cacheable for everyone. | 90 |
Description: If you set private headers on content, that means that the content are specific for that user. Static content should be able to be cached and used by everyone. Avoid setting the cache header to private. | ||
Offenders: |
Title | Advice | Score |
---|---|---|
Use a good Content-Security-Policy header to make sure you you avoid Cross Site Scripting (XSS) attacks. (contentSecurityPolicyHeader) | Set a Content-Security-Policy header to make sure you are not open for Cross Site Scripting (XSS) attacks. You can start with setting a Content-Security-Policy-Report-Only header, that will only report the violation, not stop the download. | 0 |
Description: Content Security Policy is delivered via a HTTP response header, and defines approved sources of content that the browser may load. It can be an effective countermeasure to Cross Site Scripting (XSS) attacks and is also widely supported and usually easily deployed. https://scotthelme.co.uk/content-security-policy-an-introduction/. | ||
Offenders: | ||
Set a referrer-policy header to make sure you do not leak user information. (referrerPolicyHeader) | Set a referrer-policy header to make sure you do not leak user information. | 0 |
Description: Referrer Policy is a new header that allows a site to control how much information the browser includes with navigations away from a document and should be set by all sites. https://scotthelme.co.uk/a-new-security-header-referrer-policy/. | ||
Offenders: |
Page info | |
---|---|
Title | Wikipedia, the free encyclopedia |
Generator | MediaWiki 1.36.0-wmf.22 |
Width | 1350 |
Height | 2745 |
DOM elements | 1069 |
Avg DOM depth | 11 |
Max DOM depth | 18 |
Iframes | 0 |
Script tags | 6 |
Local storage | 496.6 KB |
Session storage | 0 b |
HTML vs AMP | Plain good HTML page |
Resource Hints |
---|
dns-prefetch |
https://login.wikimedia.org/ |
https://meta.wikimedia.org/ |
preconnect |
https://upload.wikimedia.org/ |
Data collected using Wappalyzer. Use --browsertime.firefox.includeResponseBodies html
or --browsertime.chrome.includeResponseBodies html
to help Wappalyser find more information about technologies used.
Technology | Confidence | Category |
---|---|---|
MediaWiki | 100 | Wikis |
PHP | 100 | Programming languages |
Bootstrap 2 | 100 | UI frameworks |
jQuery | 100 | JavaScript libraries |
Visual Metrics | |
---|---|
First Visual Change | 536 ms |
Speed Index | 539 ms |
Visual Complete 85% | 536 ms |
Visual Complete 95% | 536 ms |
Visual Complete 99% | 637 ms |
Last Visual Change | 804 ms |
Visual Readiness | 268 ms |
Navigation Timing | |
---|---|
backEndTime | 298 ms |
domContentLoadedTime | 499 ms |
domInteractiveTime | 499 ms |
domainLookupTime | 0 ms |
frontEndTime | 692 ms |
pageDownloadTime | 4 ms |
pageLoadTime | 995 ms |
redirectionTime | 0 ms |
serverConnectionTime | 196 ms |
serverResponseTime | 88 ms |
Google Web Vitals | |
---|---|
Largest Contentful Paint (LCP) | 533 ms |
Cumulative Layout Shift (CLS) | 0.00 |
Total Blocking Time (TBT) | 16 ms |
Extra timings | |
---|---|
First Contentful Paint (FCP) | 533 ms |
First Paint | 533 ms |
Largest Contentful Paint (LCP) | 533 ms |
Load Event End | 996 ms |
Fully loaded | 1.045 s |
User Timing marks | |
---|---|
mwStartup | 517 ms |
Read more about Largest Contentful Paint.
Tag | Render time | Load time | Size |
---|---|---|---|
P | 533 ms | 0 ms | 162.4 KB |
No layout shift detected.
name | duration | description |
---|---|---|
cache | 0 | hit-front |
There are no custom configured scripts.
There are no custom extra metrics from scripting.
name | value |
---|---|
AudioHandlers | 0 |
Documents | 11 |
Frames | 6 |
JSEventListeners | 46 |
LayoutObjects | 1923 |
MediaKeySessions | 0 |
MediaKeys | 0 |
Nodes | 2741 |
Resources | 34 |
ContextLifecycleStateObservers | 24 |
V8PerContextDatas | 1 |
WorkerGlobalScopes | 0 |
UACSSResources | 0 |
RTCPeerConnections | 0 |
ResourceFetchers | 11 |
AdSubframes | 0 |
DetachedScriptStates | 0 |
ArrayBufferContents | 2 |
LayoutCount | 10 |
RecalcStyleCount | 14 |
LayoutDuration | 72 |
RecalcStyleDuration | 42 |
DevToolsCommandDuration | 10 |
ScriptDuration | 216 |
V8CompileDuration | 6 |
TaskDuration | 534 |
TaskOtherDuration | 189 |
ThreadTime | 0 |
ProcessTime | 1 |
JSHeapUsedSize | 6904944 |
JSHeapTotalSize | 10768384 |
FirstMeaningfulPaint | 533 |
How the page is built.
Summary | |
---|---|
HTTP version | HTTP/2.0 |
Total requests | 33 |
Total domains | 3 |
Total transfer size | 324.6 KB |
Total content size | 929.7 KB |
Responses missing compression | 8 |
Number of cookies | 2 |
Third party cookies | 0 |
Requests per response code | |
---|---|
200 | 33 |
Content | Header Size | Transfer Size | Content Size | Requests |
---|---|---|---|---|
html | 0 b | 20.7 KB | 81.7 KB | 1 |
css | 0 b | 13.6 KB | 55.3 KB | 2 |
javascript | 0 b | 196.2 KB | 700.9 KB | 6 |
image | 0 b | 91.2 KB | 87.7 KB | 19 |
svg | 0 b | 1.7 KB | 1.5 KB | 4 |
favicon | 0 b | 1.2 KB | 2.7 KB | 1 |
Total | 0 b | 324.6 KB | 929.7 KB | 33 |
Domain | Header Size | Transfer Size | Content Size | Requests |
---|---|---|---|---|
en.wikipedia.org | N/A | 241.5 KB | 850.2 KB | 14 |
upload.wikimedia.org | N/A | 82.6 KB | 79.3 KB | 18 |
login.wikimedia.org | N/A | 465 B | 236 B | 1 |
type | min | median | max |
---|---|---|---|
Expires | 0 seconds | 0 seconds | 1 year |
Last modified | 10 seconds | 1 week | 5 years |
Content | Transfer Size | Requests |
---|---|---|
html | 0 b | 0 |
css | 0 b | 0 |
javascript | 19.1 KB | 2 |
image | 0 b | 0 |
font | 0 b | 0 |
svg | 671 B | 1 |
favicon | 1.2 KB | 1 |
Total | 21.0 KB | 4 |
Includes requests done after onLoad.
Content | Transfer Size | Requests |
---|---|---|
html | 0 b | 0 |
css | 0 b | 0 |
javascript | 174.8 KB | 5 |
image | 0 b | 0 |
font | 0 b | 0 |
svg | 671 B | 1 |
favicon | 1.2 KB | 1 |
Total | 176.7 KB | 7 |
Download the Chrome trace log and drag and drop it into Developer Tools / Performance in Chrome.
Collected using the Long Task API. A long task is a task that take 50 milliseconds or more.
Type | Quantity | Total duration (ms) |
---|---|---|
Total Blocking Time | 16 | |
Max Potential First Input Delay | 66 | |
Long Tasks before First Paint | 1 | 91 |
Long Tasks before First Contentful Paint | 1 | 91 |
Long Tasks after Load Event End | 0 | 0 |
Total Long Tasks | 2 | 157 |
name | startTime | duration | containerId | containerName | containerSrc | containerType |
---|---|---|---|---|---|---|
unknown | 407 | 91 | window | |||
self | 818 | 66 | window |
Calculated using Tracium.
Categories (ms) | |
---|---|
parseHTML | 30 |
styleLayout | 113 |
paintCompositeRender | 37 |
scriptParseCompile | 7 |
scriptEvaluation | 217 |
garbageCollection | 15 |
other | 131 |
Events (ms) | |
---|---|
V8.Execute | 200 |
RunTask | 125 |
Layout | 72 |
UpdateLayoutTree | 41 |
ParseHTML | 28 |
Paint | 13 |
Tool/domain | Time (ms) |
---|---|
en.wikipedia.org | 255.1 |
Third party requests categorised by Third party web.
Calculated using (.*wikipedia.*||.*wikimedia.*) (use --firstParty
to configure).
Content | Header Size | Transfer Size | Content Size | Requests |
---|---|---|---|---|
html | 0 b | 20.7 KB | 81.7 KB | 1 |
css | 0 b | 13.6 KB | 55.3 KB | 2 |
javascript | 0 b | 196.2 KB | 700.9 KB | 6 |
image | 0 b | 91.2 KB | 87.7 KB | 19 |
font | 0 b | 0 b | 0 b | 0 |
svg | 0 b | 1.7 KB | 1.5 KB | 4 |
favicon | 0 b | 1.2 KB | 2.7 KB | 1 |
Total | N/A | 324.6 KB | 929.7 KB | 33 |
Content | Header Size | Transfer Size | Content Size | Requests |
---|---|---|---|---|
html | 0 b | 0 b | 0 b | 0 |
css | 0 b | 0 b | 0 b | 0 |
javascript | 0 b | 0 b | 0 b | 0 |
image | 0 b | 0 b | 0 b | 0 |
font | 0 b | 0 b | 0 b | 0 |
Total | N/A | N/A | N/A |