Benchmarks
Plugin footprint 40% from 16 tests
Installer 0% from 1 test
🔺 Critical test (weight: 50) | The install procedure must perform silently
The following installer errors require your attention
- Install procedure had errors
- > Notice in wp-content/plugins/contact-form-by-fulfills/php/js.php+5
Undefined index: page
Server metrics [RAM: ▼1.93MB] [CPU: ▼54.08ms] Passed 4 tests
This is a short check of server-side resources used by Contact Form By FULFILLs
No issues were detected with server-side resource usage
Page | Memory (MB) | CPU Time (ms) |
---|---|---|
Home / | 2.06 ▼1.41 | 5.37 ▼38.20 |
Dashboard /wp-admin | 2.08 ▼1.23 | 8.34 ▼47.46 |
Posts /wp-admin/edit.php | 2.08 ▼1.28 | 7.04 ▼46.79 |
Add New Post /wp-admin/post-new.php | 2.08 ▼3.81 | 7.61 ▼83.87 |
Media Library /wp-admin/upload.php | 2.08 ▼1.15 | 6.79 ▼29.17 |
Inbox /wp-admin/admin.php?page=contact-form-by-fulfills-reply | 3.09 | 28.87 |
Other Settings /wp-admin/admin.php?page=contact-form-by-fulfills-other | 3.10 | 27.31 |
About Us /wp-admin/admin.php?page=contact-form-by-fulfills | 3.09 | 24.16 |
Form Settings /wp-admin/admin.php?page=contact-form-by-fulfills-edit | 3.10 | 26.60 |
Server storage [IO: ▲0.07MB] [DB: ▲0.00MB] Passed 3 tests
How much does this plugin use your filesystem and database?
The plugin installed successfully
Filesystem: 38 new files
Database: no new tables, 6 new options
New WordPress options |
---|
widget_theysaidso_widget |
widget_recent-posts |
widget_recent-comments |
db_upgraded |
can_compress_scripts |
theysaidso_admin_options |
Browser metrics Passed 4 tests
A check of browser resources used by Contact Form By FULFILLs
Minimal impact on browser resources
Page | Nodes | Memory (MB) | Script (ms) | Layout (ms) |
---|---|---|---|---|
Home / | 2,820 ▲59 | 14.24 ▼0.49 | 1.87 ▲0.08 | 44.09 ▼5.80 |
Dashboard /wp-admin | 2,229 ▲49 | 5.67 ▼0.00 | 92.68 ▼3.88 | 42.89 ▼1.55 |
Posts /wp-admin/edit.php | 2,131 ▲28 | 1.97 ▼0.03 | 40.28 ▲2.19 | 37.81 ▲1.96 |
Add New Post /wp-admin/post-new.php | 1,553 ▲25 | 23.24 ▲0.02 | 686.01 ▼10.73 | 52.31 ▲0.53 |
Media Library /wp-admin/upload.php | 1,428 ▲31 | 4.17 ▼0.03 | 102.61 ▼10.50 | 46.31 ▼1.02 |
Inbox /wp-admin/admin.php?page=contact-form-by-fulfills-reply | 835 | 2.03 | 23.92 | 26.52 |
Other Settings /wp-admin/admin.php?page=contact-form-by-fulfills-other | 937 | 2.00 | 25.32 | 30.82 |
About Us /wp-admin/admin.php?page=contact-form-by-fulfills | 824 | 2.02 | 23.57 | 37.28 |
Form Settings /wp-admin/admin.php?page=contact-form-by-fulfills-edit | 910 | 1.96 | 31.38 | 41.37 |
Uninstaller [IO: ▲0.00MB] [DB: ▲0.00MB] 50% from 4 tests
🔸 Tests weight: 35 | The uninstall procedure must remove all plugin files and extra database tables
Please fix the following items
- Uninstall procedure validation failed for this plugin
- > Notice in wp-content/plugins/contact-form-by-fulfills/php/js.php+5
Undefined index: page
- The uninstall procedure has failed, leaving 6 options in the database
- widget_recent-posts
- db_upgraded
- theysaidso_admin_options
- widget_recent-comments
- can_compress_scripts
- widget_theysaidso_widget
Smoke tests 75% from 4 tests
Server-side errors 0% from 1 test
🔹 Test weight: 20 | A shallow check that no server-side errors were triggered
These server-side errors were triggered
- 15 occurences, only the last one shown
- > GET request to /wp-admin/admin.php?page=contact-form-by-fulfills-edit
- > Notice in wp-content/plugins/contact-form-by-fulfills/pages/form-settings/edit.php+54
Trying to access array offset on value of type bool
- 6 occurences, only the last one shown
- > GET request to /wp-admin/admin.php?page=contact-form-by-fulfills-reply
- > Notice in wp-content/plugins/contact-form-by-fulfills/pages/inbox/includes/listpage.php+31
Undefined index: status
- > GET request to /wp-admin/admin.php?page=contact-form-by-fulfills-edit
- > Warning in wp-content/plugins/contact-form-by-fulfills/pages/form-settings/includes/inputs.php+64
Invalid argument supplied for foreach()
SRP Passed 2 tests
🔹 Tests weight: 20 | The single-responsibility principle applies for WordPress plugins as well - please make sure your PHP files perform no actions when accessed directly
Everything seems fine, however this is by no means an exhaustive test
User-side errors Passed 1 test
🔹 Test weight: 20 | This is a smoke test targeting browser errors/issues
No browser errors were detected
Optimizations
Plugin configuration 93% from 29 tests
readme.txt 94% from 16 tests
You should put a lot of thought into formatting readme.txt as it is used by WordPress.org to prepare the public listing of your plugin
Attributes that need to be fixed:
- Screenshots: Add descriptions for screenshots #1, #2, #3 in contact-form-by-fulfills/assets to your readme.txt
contact-form-by-fulfills/contact-form-by-fulfills.php 92% from 13 tests
The main PHP file in "Contact Form By FULFILLs" ver. 1.1.0 adds more information about the plugin and also serves as the entry point for this plugin
You should first fix the following items:
- Description: Keep the plugin description shorter than 140 characters (currently 141 characters long)
Code Analysis Passed 3 tests
File types Passed 1 test
🔸 Test weight: 35 | Executable files are not allowed as they can serve as attack vectors
Success! There were no dangerous files found in this plugin1,408 lines of code in 35 files:
Language | Files | Blank lines | Comment lines | Lines of code |
---|---|---|---|---|
PHP | 25 | 71 | 41 | 832 |
CSS | 4 | 52 | 7 | 319 |
JavaScript | 6 | 34 | 17 | 257 |
PHP code Passed 2 tests
Analyzing logical lines of code, cyclomatic complexity, and other code metrics
There were no cyclomatic complexity issued detected
Cyclomatic complexity | |
---|---|
Average complexity per logical line of code | 0.35 |
Average class complexity | 0.00 |
▷ Minimum class complexity | 0.00 |
▷ Maximum class complexity | 0.00 |
Average method complexity | 0.00 |
▷ Minimum method complexity | 0.00 |
▷ Maximum method complexity | 0.00 |
Code structure | ||
---|---|---|
Namespaces | 0 | |
Interfaces | 0 | |
Traits | 0 | |
Classes | 0 | |
▷ Abstract classes | 0 | 0.00% |
▷ Concrete classes | 0 | 0.00% |
▷ Final classes | 0 | 0.00% |
Methods | 0 | |
▷ Static methods | 0 | 0.00% |
▷ Public methods | 0 | 0.00% |
▷ Protected methods | 0 | 0.00% |
▷ Private methods | 0 | 0.00% |
Functions | 34 | |
▷ Named functions | 34 | 100.00% |
▷ Anonymous functions | 0 | 0.00% |
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
All PNG images should be compressed to minimize bandwidth usage for end users
There were not PNG files found in your plugin