Sprout Invoices 19.6.1

Does Sprout Invoices work with WordPress 5.0.3 and PHP 7.0.16? A smoke test was performed on .

Summary

Errors
1PHP notices
1Unrecognized messages in the PHP error log
7JavaScript exceptions
All test pages loaded successfully
No resource errors
Performance

Memory usage: 1.88 MiB
The average PHP memory usage increased by this amount after activating by the plugin.

Page speed impact: insignificant.
The plugin didn't make the site noticeably slower.

Environment
WordPress version5.0.3
PHP version7.0.16
MySQL version5.7.17
PHP memory limit256M
Plugin Info
Last updated
Active installs 2,000+
WordPress.org page https://wordpress.org/plugins/sprout-invoices/
Badges

WordPress compatibility badge PHP compatibility badge

Get badge code

Pages 18

Getting Started ‹ Test site — WordPress

Page screenshot: Getting Started ‹ Test site — WordPress
URL /wp-admin/admin.php?page=sprout-invoices
Requested URL /wp-admin/plugins.php?action=activate&plugin=sprout-invoices%2Fsprout-invoices.php&plugin_status=all&paged=1&s&_wpnonce=46f2c6e86a
Aspect after-activation
HTTP status 200
Load time 2.232 s
Memory usage 5.27 MiB
JS errors None
Resource errors None

Invoices

Page screenshot: Invoices
URL /wp-admin/edit.php?post_type=sa_invoice
Aspect menu-item
HTTP status 200
Load time 0.284 s
Memory usage 5.2 MiB
JS errors None
Resource errors None

Invoices → Add Invoice

Page screenshot: Invoices → Add Invoice
URL /wp-admin/post-new.php?post_type=sa_invoice
Aspect menu-item
HTTP status 200
Load time 0.919 s
Memory usage 5.27 MiB
JS errors None
Resource errors None

Invoices → Payments

Page screenshot: Invoices → Payments
URL /wp-admin/edit.php?post_type=sa_invoice&page=sprout-apps%2Finvoice_payments
Requested URL /wp-admin/edit.php?post_type=sa_invoice&page=sprout-apps/invoice_payments
Aspect menu-item
HTTP status 200
Load time 0.300 s
Memory usage 5.12 MiB
JS errors None
Resource errors None

Invoices → Clients

Page screenshot: Invoices → Clients
URL /wp-admin/edit.php?post_type=sa_client
Aspect menu-item
HTTP status 200
Load time 0.302 s
Memory usage 5.21 MiB
JS errors None
Resource errors None

Invoices → Projects

Page screenshot: Invoices → Projects
URL /wp-admin/edit.php?post_type=sa_project
Aspect menu-item
HTTP status 200
Load time 0.219 s
Memory usage 5.2 MiB
JS errors None
Resource errors None

Estimates

Page screenshot: Estimates
URL /wp-admin/edit.php?post_type=sa_estimate
Aspect menu-item
HTTP status 200
Load time 0.275 s
Memory usage 5.2 MiB
JS errors None
Resource errors None

Estimates → Add Estimate

Page screenshot: Estimates → Add Estimate
URL /wp-admin/post-new.php?post_type=sa_estimate
Aspect menu-item
HTTP status 200
Load time 0.821 s
Memory usage 5.26 MiB
JS errors None
Resource errors None

Tools → Sprout Records

Page screenshot: Tools → Sprout Records
URL /wp-admin/tools.php?page=si_records
Aspect menu-item
HTTP status 200
Load time 0.251 s
Memory usage 5.12 MiB
JS errors None
Resource errors None

Sprout Invoices

Page screenshot: Sprout Invoices
URL /wp-admin/admin.php?page=sprout-invoices
Aspect menu-item
HTTP status 200
Load time 0.550 s
Memory usage 5.12 MiB
JS errors None
Resource errors None

Sprout Invoices → General Settings

Page screenshot: Sprout Invoices → General Settings
URL /wp-admin/admin.php?page=sprout-invoices-settings
Aspect menu-item
HTTP status 200
Load time 3.535 s
Memory usage 5.12 MiB
JS errors None
Resource errors None

Sprout Invoices → Payment Settings

Page screenshot: Sprout Invoices → Payment Settings
URL /wp-admin/admin.php?page=sprout-invoices-payments
Aspect menu-item
HTTP status 200
Load time 0.328 s
Memory usage 5.12 MiB
JS errors None
Resource errors None

Sprout Invoices → Notifications

Page screenshot: Sprout Invoices → Notifications
URL /wp-admin/admin.php?page=sprout-invoices-notifications
Aspect menu-item
HTTP status 200
Load time 0.588 s
Memory usage 5.12 MiB
JS errors None
Resource errors None

Sprout Invoices → Add-ons

Page screenshot: Sprout Invoices → Add-ons
URL /wp-admin/admin.php?page=sprout-invoices-addons
Aspect menu-item
HTTP status 200
Load time 4.819 s
Memory usage 5.96 MiB
JS errors None
Resource errors None

Sprout Invoices → Reports

Page screenshot: Sprout Invoices → Reports
URL /wp-admin/admin.php?page=sprout-invoices-reports
Aspect menu-item
HTTP status 200
Load time 0.346 s
Memory usage 5.14 MiB
JS errors
[
    {
        "message": "TypeError: Cannot read property 'length' of undefined\n    at s.buildScale (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:11:9205)\n    at s.<anonymous> (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:11:8189)\n    at Object.s.each (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:1836)\n    at s.initialize (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:11:7706)\n    at s.e.Type (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:10855)\n    at new s (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:14765)\n    at e.(anonymous function) [as Line] (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:15107)\n    at payments_chart (/wp-admin/admin.php?page=sprout-invoices-reports:477:32)\n    at Object.success (/wp-admin/admin.php?page=sprout-invoices-reports:518:7)\n    at i (/wp-admin/load-scripts.php?c=0&load%5B%5D=jquery-core,jquery-migrate,utils&ver=5.0.3:2:27449)",
        "trace": null,
        "code": null
    },
    {
        "message": "TypeError: Cannot read property 'length' of undefined\n    at s.buildScale (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:11:9205)\n    at s.<anonymous> (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:11:8189)\n    at Object.s.each (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:1836)\n    at s.initialize (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:11:7706)\n    at s.e.Type (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:10855)\n    at new s (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:14765)\n    at e.(anonymous function) [as Line] (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:15107)\n    at payments_chart (/wp-admin/admin.php?page=sprout-invoices-reports:477:32)\n    at Object.success (/wp-admin/admin.php?page=sprout-invoices-reports:518:7)\n    at i (/wp-admin/load-scripts.php?c=0&load%5B%5D=jquery-core,jquery-migrate,utils&ver=5.0.3:2:27449)",
        "trace": null,
        "code": null
    },
    {
        "message": "TypeError: Cannot read property 'length' of undefined\n    at s.buildScale (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:11:790)\n    at s.initialize (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:31645)\n    at s.e.Type (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:10855)\n    at new s (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:14765)\n    at e.(anonymous function) [as Bar] (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:15107)\n    at est_invoices_chart (/wp-admin/admin.php?page=sprout-invoices-reports:623:32)\n    at Object.success (/wp-admin/admin.php?page=sprout-invoices-reports:661:7)\n    at i (/wp-admin/load-scripts.php?c=0&load%5B%5D=jquery-core,jquery-migrate,utils&ver=5.0.3:2:27449)\n    at Object.fireWith [as resolveWith] (/wp-admin/load-scripts.php?c=0&load%5B%5D=jquery-core,jquery-migrate,utils&ver=5.0.3:2:28213)\n    at y (/wp-admin/load-scripts.php?c=0&load%5B%5D=jquery-core,jquery-migrate,utils&ver=5.0.3:4:22721)",
        "trace": null,
        "code": null
    },
    {
        "message": "TypeError: Cannot read property 'length' of undefined\n    at s.buildScale (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:11:790)\n    at s.initialize (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:31645)\n    at s.e.Type (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:10855)\n    at new s (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:14765)\n    at e.(anonymous function) [as Bar] (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:15107)\n    at est_invoices_chart (/wp-admin/admin.php?page=sprout-invoices-reports:623:32)\n    at dispatch (/wp-admin/load-scripts.php?c=0&load%5B%5D=jquery-core,jquery-migrate,utils&ver=5.0.3:3:12444)\n    at r.handle (/wp-admin/load-scripts.php?c=0&load%5B%5D=jquery-core,jquery-migrate,utils&ver=5.0.3:3:9173)",
        "trace": null,
        "code": null
    },
    {
        "message": "TypeError: Cannot read property 'update' of undefined\n    at s.reflow (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:11:10914)\n    at s.render (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:11395)\n    at s.resize (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:11298)\n    at /wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:29582\n    at s.each (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:1886)\n    at /wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:29532",
        "trace": null,
        "code": null
    },
    {
        "message": "TypeError: Cannot read property 'length' of undefined\n    at s.buildScale (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:11:790)\n    at s.initialize (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:31645)\n    at s.e.Type (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:10855)\n    at new s (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:14765)\n    at e.(anonymous function) [as Bar] (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:15107)\n    at est_invoices_chart (/wp-admin/admin.php?page=sprout-invoices-reports:623:32)\n    at dispatch (/wp-admin/load-scripts.php?c=0&load%5B%5D=jquery-core,jquery-migrate,utils&ver=5.0.3:3:12444)\n    at r.handle (/wp-admin/load-scripts.php?c=0&load%5B%5D=jquery-core,jquery-migrate,utils&ver=5.0.3:3:9173)",
        "trace": null,
        "code": null
    }
]
Resource errors None

Sprout Invoices → Import

Page screenshot: Sprout Invoices → Import
URL /wp-admin/admin.php?page=sprout-invoices-import
Aspect menu-item
HTTP status 200
Load time 0.319 s
Memory usage 5.12 MiB
JS errors
[
    {
        "message": "TypeError: Cannot read property 'update' of undefined\n    at s.reflow (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:11:10914)\n    at s.render (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:11395)\n    at s.resize (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:11298)\n    at /wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:29582\n    at s.each (/wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:1886)\n    at /wp-content/plugins/sprout-invoices/resources/admin/plugins/chartjs/chart.min.js?ver=5.0.3:10:29532",
        "trace": null,
        "code": null
    }
]
Resource errors None

Test site – Just another WordPress site

Page screenshot: Test site – Just another WordPress site
URL /
Aspect front-page
HTTP status 200
Load time 0.253 s
Memory usage 4.35 MiB
JS errors None
Resource errors None

Dashboard ‹ Test site — WordPress

Page screenshot: Dashboard ‹ Test site — WordPress
URL /wp-admin/index.php
Aspect new-meta-boxes
HTTP status 200
Load time 0.361 s
Memory usage 5.14 MiB
JS errors None
Resource errors None

Benchmark

URL Load time Memory usage
Inactive Active Change Inactive Active Change
/wp-admin/index.php0.330 s0.285 s-0.045 s3.22 MiB5.14 MiB+ 1.92 MiB
/wp-admin/edit.php0.217 s0.229 s+0.012 s3.25 MiB5.22 MiB+ 1.97 MiB
/wp-admin/post-new.php1.039 s1.301 s+0.262 s4.92 MiB6.67 MiB+ 1.75 MiB
/wp-admin/upload.php0.449 s0.368 s-0.081 s3.15 MiB5.13 MiB+ 1.99 MiB
/wp-admin/options-writing.php0.268 s0.186 s-0.082 s3.17 MiB5.12 MiB+ 1.95 MiB
/wp-admin/media-new.php0.272 s0.295 s+0.023 s3.07 MiB5.12 MiB+ 2.05 MiB
/wp-admin/edit-tags.php?taxonomy=category0.292 s0.275 s-0.017 s3.17 MiB5.14 MiB+ 1.97 MiB
/wp-admin/post-new.php?post_type=page1.180 s1.150 s-0.030 s4.9 MiB6.65 MiB+ 1.74 MiB
/wp-admin/options-discussion.php0.270 s0.337 s+0.067 s3.07 MiB5.12 MiB+ 2.04 MiB
/wp-admin/edit-comments.php0.256 s0.296 s+0.040 s3.18 MiB5.14 MiB+ 1.97 MiB
/0.349 s0.242 s-0.107 s3 MiB4.35 MiB+ 1.35 MiB
Average 0.447 s0.451 s+0.004 s3.46 MiB5.35 MiB+ 1.88 MiB

Additions

Things that the plugin adds to the site. This section is not intended to be comprehensive. The test tool only looks for a few specific types of added content.

Options wp_options 7

Custom Post Types 7

ID Name
sa_recordRecords
sa_notificationNotifications
sa_invoiceInvoices
sa_estimateEstimates
sa_clientClients
sa_paymentPayments
sa_projectProjects

Meta Boxes

{
    "dashboard": {
        "invoice_dashboard": {
            "title": "Invoices Dashboard",
            "context": "normal"
        },
        "estimates_dashboard": {
            "title": "Estimates Dashboard",
            "context": "side"
        }
    },
    "sa_notification": {
        "si_notification_submit": {
            "title": "Update",
            "context": "side"
        },
        "si_notification_shortcodes_send_estimate": {
            "title": "Estimate Available Shortcodes",
            "context": "normal"
        },
        "si_notification_shortcodes_send_invoice": {
            "title": "Invoice Available Shortcodes",
            "context": "normal"
        },
        "si_notification_shortcodes_deposit_payment": {
            "title": "Deposit Payment Received Shortcodes",
            "context": "normal"
        },
        "si_notification_shortcodes_payment_cleared": {
            "title": "Payment Cleared Shortcodes",
            "context": "normal"
        },
        "si_notification_shortcodes_final_payment": {
            "title": "Invoice Paid Shortcodes",
            "context": "normal"
        },
        "si_notification_shortcodes_reminder_payment": {
            "title": "Payment Reminder Shortcodes",
            "context": "normal"
        },
        "si_notification_shortcodes_accepted_estimate": {
            "title": "Estimate Accepted Shortcodes",
            "context": "normal"
        },
        "si_notification_shortcodes_declined_estimate": {
            "title": "Estimate Declined Shortcodes",
            "context": "normal"
        },
        "si_notification_shortcodes_payment_notification": {
            "title": "Payment Received Shortcodes",
            "context": "normal"
        }
    },
    "sa_client": {
        "si_client_information": {
            "title": "Information",
            "context": "normal"
        },
        "si_client_advanced": {
            "title": "Advanced",
            "context": "normal"
        },
        "si_client_history": {
            "title": "History",
            "context": "normal"
        },
        "si_client_submit": {
            "title": "Update",
            "context": "side"
        }
    },
    "sa_invoice": {
        "si_invoice_line_items": {
            "title": "Management",
            "context": "normal"
        },
        "si_invoice_update": {
            "title": "Information",
            "context": "normal"
        },
        "si_invoice_history": {
            "title": "Invoice History",
            "context": "normal"
        },
        "si_doc_send": {
            "title": "Send Notification",
            "context": "normal"
        },
        "si_invoice_payment": {
            "title": "Admin Payment",
            "context": "normal"
        },
        "si_invoice_notes": {
            "title": "Terms & Notes",
            "context": "normal"
        }
    },
    "sa_estimate": {
        "si_estimate_line_items": {
            "title": "Management",
            "context": "normal"
        },
        "si_estimate_update": {
            "title": "Information",
            "context": "normal"
        },
        "si_estimate_history": {
            "title": "Estimate History",
            "context": "normal"
        },
        "si_doc_send": {
            "title": "Send Notification",
            "context": "normal"
        },
        "si_estimate_notes": {
            "title": "Terms & Notes",
            "context": "normal"
        }
    },
    "sa_project": {
        "si_project_information": {
            "title": "Information",
            "context": "normal"
        },
        "si_project_history": {
            "title": "History",
            "context": "normal"
        },
        "si_project_submit": {
            "title": "Update",
            "context": "side"
        },
        "psp_project_info": {
            "title": "Project Panorama",
            "context": "side"
        }
    }
}

Roles 1

ID Name
sa_clientClient

Capabilities 8

PHP Error Log 2 lines

[23-Jan-2019 04:49:57 UTC] PHP Notice:  Undefined variable: key in /wp-content/plugins/sprout-invoices/views/admin/addons/free-settings.php on line 38
[23-Jan-2019 04:50:08 UTC] ** Sprout_Invoices Already Loaded **
See also: All tests for this plugin, How to Hide Sprout Invoices Admin Menus and More