Benchmarks
Plugin footprint 83% from 16 tests
Installer Passed 1 test
🔺 Critical test (weight: 50) | The install procedure must perform silently
The plugin installed successfully, without throwing any errors or notices
Server metrics [RAM: ▲0.13MB] [CPU: ▲0.94ms] Passed 4 tests
Server-side resources used by Widgets for Hotels.com Reviews
Normal server usage
Page | Memory (MB) | CPU Time (ms) |
---|---|---|
Home / | 3.56 ▲0.10 | 43.64 ▲6.06 |
Dashboard /wp-admin | 3.43 ▲0.13 | 51.74 ▲1.13 |
Posts /wp-admin/edit.php | 3.53 ▲0.17 | 50.74 ▲1.57 |
Add New Post /wp-admin/post-new.php | 6.14 ▲0.25 | 86.12 ▼2.62 |
Media Library /wp-admin/upload.php | 3.37 ▲0.14 | 37.67 ▲3.69 |
Server storage [IO: ▲3.23MB] [DB: ▲0.00MB] Passed 3 tests
Analyzing filesystem and database footprints of this plugin
The plugin installed successfully
Filesystem: 131 new files
Database: 1 new table, 8 new options
New tables |
---|
wp_trustindex_hotels_reviews |
New WordPress options |
---|
db_upgraded |
can_compress_scripts |
trustindex-hotels-active |
trustindex-hotels-version |
theysaidso_admin_options |
widget_recent-comments |
widget_recent-posts |
widget_theysaidso_widget |
Browser metrics Passed 4 tests
Checking browser requirements for Widgets for Hotels.com Reviews
This plugin has a minimal impact on browser resources
Page | Nodes | Memory (MB) | Script (ms) | Layout (ms) |
---|---|---|---|---|
Home / | 2,809 ▲47 | 14.58 ▼0.13 | 1.75 ▲0.01 | 44.01 ▲5.93 |
Dashboard /wp-admin | 2,202 ▲28 | 5.54 ▼0.12 | 93.76 ▼2.94 | 76.76 ▲32.96 |
Posts /wp-admin/edit.php | 2,122 ▲19 | 1.99 ▲0.01 | 39.40 ▼0.62 | 35.24 ▲4.08 |
Add New Post /wp-admin/post-new.php | 6,426 ▲4,900 | 29.26 ▲5.42 | 940.43 ▲304.04 | 42.66 ▼3.80 |
Media Library /wp-admin/upload.php | 1,413 ▲13 | 4.23 ▲0.04 | 100.22 ▲5.04 | 66.28 ▲26.70 |
Uninstaller [IO: ▲0.00MB] [DB: ▲0.00MB] 75% from 4 tests
🔸 Tests weight: 35 | It is important to correctly uninstall your plugin, without leaving any traces
Please fix the following items
- Zombie WordPress options detected upon uninstall: 6 options
- widget_recent-comments
- can_compress_scripts
- db_upgraded
- theysaidso_admin_options
- widget_recent-posts
- widget_theysaidso_widget
Smoke tests 50% from 4 tests
Server-side errors Passed 1 test
🔹 Test weight: 20 | A shallow check that no server-side errors were triggered
Even though everything seems fine, this is not an exhaustive test
SRP 0% from 2 tests
🔹 Tests weight: 20 | It is important to ensure that your PHP files perform no action when accessed directly, respecting the single-responsibility principle
The following issues need your attention
- 11× PHP files perform the action of outputting non-empty strings when accessed directly (only 10 are shown):
- > /wp-content/plugins/review-widgets-for-hotels-com/settings.php
- > /wp-content/plugins/review-widgets-for-hotels-com/review-widgets-for-hotels-com.php
- > /wp-content/plugins/review-widgets-for-hotels-com/tabs/advanced.php
- > /wp-content/plugins/review-widgets-for-hotels-com/tabs/feature_request.php
- > /wp-content/plugins/review-widgets-for-hotels-com/trustindex-hotels-widget.class.php
- > /wp-content/plugins/review-widgets-for-hotels-com/tabs/my_reviews.php
- > /wp-content/plugins/review-widgets-for-hotels-com/tabs/setup_no_reg_header.php
- > /wp-content/plugins/review-widgets-for-hotels-com/tabs/rate.php
- > /wp-content/plugins/review-widgets-for-hotels-com/tabs/get_reviews.php
- > /wp-content/plugins/review-widgets-for-hotels-com/tabs/setup_trustindex.php
- 12× GET requests to PHP files trigger server-side errors or Error 500 responses (only 10 are shown):
- > PHP Warning
require_once(ABSPATHwp-admin/includes/upgrade.php): failed to open stream: No such file or directory in wp-content/plugins/review-widgets-for-hotels-com/include/activate.php on line 2
- > PHP Fatal error
Uncaught Error: Call to undefined function plugin_dir_path() in wp-content/plugins/review-widgets-for-hotels-com/tabs/setup_no_reg.php:1
- > PHP Fatal error
Uncaught Error: Class 'TrustindexPlugin_hotels' not found in wp-content/plugins/review-widgets-for-hotels-com/tabs/demo_widgets.php:6
- > PHP Warning
Use of undefined constant ABSPATH - assumed 'ABSPATH' (this will throw an Error in a future version of PHP) in wp-content/plugins/review-widgets-for-hotels-com/include/activate.php on line 2
- > PHP Fatal error
Uncaught Error: Class 'TrustindexPlugin_hotels' not found in wp-content/plugins/review-widgets-for-hotels-com/tabs/setup_no_reg_platform.php:1
- > PHP Fatal error
Uncaught Error: Using $this when not in object context in wp-content/plugins/review-widgets-for-hotels-com/include/schema.php:4
- > PHP Fatal error
Uncaught Error: Using $this when not in object context in wp-content/plugins/review-widgets-for-hotels-com/include/uninstall.php:2
- > PHP Fatal error
Uncaught Error: Class 'TrustindexPlugin_hotels' not found in wp-content/plugins/review-widgets-for-hotels-com/tabs/_get_more_customers.php:1
- > PHP Fatal error
Uncaught Error: Call to undefined function plugin_dir_path() in wp-content/plugins/review-widgets-for-hotels-com/uninstall.php:2
- > PHP Fatal error
require_once(): Failed opening required 'ABSPATHwp-admin/includes/upgrade.php' (include_path='.:/usr/share/php') in wp-content/plugins/review-widgets-for-hotels-com/include/activate.php on line 2
- > PHP Warning
User-side errors Passed 1 test
🔹 Test weight: 20 | This is just a short smoke test looking for browser issues
There were no browser issues found
Optimizations
Plugin configuration 97% from 29 tests
readme.txt 94% from 16 tests
The readme.txt file uses markdown syntax to describe your plugin to the world
Please fix the following attributes:
- Tags: There are too many tags (14 tag instead of maximum 10)
review-widgets-for-hotels-com/review-widgets-for-hotels-com.php Passed 13 tests
The primary PHP file in "Widgets for Hotels.com Reviews" version 11.1 is used by WordPress to initiate all plugin functionality
122 characters long description:
Embed Hotels.com reviews fast and easily into your WordPress site. Increase SEO, trust and sales using Hotels.com reviews.
Code Analysis Passed 3 tests
File types Passed 1 test
🔸 Test weight: 35 | Executable files are considered dangerous and should not be included with any WordPress plugin
Good job! No executable or dangerous file extensions detected10,475 lines of code in 38 files:
Language | Files | Blank lines | Comment lines | Lines of code |
---|---|---|---|---|
PHP | 23 | 43 | 38 | 9,281 |
JavaScript | 6 | 301 | 175 | 1,018 |
CSS | 4 | 13 | 0 | 63 |
SVG | 4 | 2 | 0 | 61 |
JSON | 1 | 0 | 0 | 52 |
PHP code Passed 2 tests
This plugin's cyclomatic complexity and code structure detailed below
Great job! No cyclomatic complexity issues were detected in this plugin
Cyclomatic complexity | |
---|---|
Average complexity per logical line of code | 0.43 |
Average class complexity | 127.00 |
▷ Minimum class complexity | 10.00 |
▷ Maximum class complexity | 348.00 |
Average method complexity | 4.17 |
▷ Minimum method complexity | 1.00 |
▷ Maximum method complexity | 59.00 |
Code structure | ||
---|---|---|
Namespaces | 0 | |
Interfaces | 0 | |
Traits | 0 | |
Classes | 3 | |
▷ Abstract classes | 0 | 0.00% |
▷ Concrete classes | 3 | 100.00% |
▷ Final classes | 0 | 0.00% |
Methods | 98 | |
▷ Static methods | 6 | 6.12% |
▷ Public methods | 96 | 97.96% |
▷ Protected methods | 0 | 0.00% |
▷ Private methods | 2 | 2.04% |
Functions | 17 | |
▷ Named functions | 8 | 47.06% |
▷ Anonymous functions | 9 | 52.94% |
Constants | 0 | |
▷ Global constants | 0 | 0.00% |
▷ Class constants | 0 | 0.00% |
▷ Public constants | 0 | 0.00% |
Plugin size Passed 2 tests
Image compression Passed 2 tests
PNG files should be compressed to save space and minimize bandwidth usage
4 PNG files occupy 0.02MB with 0.01MB in potential savings
Potential savings
Compression of 4 random PNG files using pngquant | |||
---|---|---|---|
File | Size - original | Size - compressed | Savings |
static/img/platforms.png | 10.24KB | 4.08KB | ▼ 60.12% |
static/img/yes.png | 1.91KB | 0.25KB | ▼ 87.08% |
static/img/trustindex-sign-logo.png | 3.34KB | 0.59KB | ▼ 82.47% |
static/img/no.png | 1.92KB | 0.28KB | ▼ 85.53% |