Skip to content

Testing Guidelines for Shopware Extensions

You are viewing an outdated version of the documentation.
Click here to switch to the stable version (v6.6), or use the version switcher on the left to navigate between versions.

Testing Guidelines for Shopware Extensions

This section guides you with the criteria used to test your extension. Detailed information is available on quality guidelines for apps and quality guidelines for plugins.

Check out the points that affect your extension and go through them before submitting it for testing.

We assign three statuses when testing your extension:

TIP

OK: This point was tested and passed

DANGER

Failed: This point was tested, and errors were found

WARNING

Not necessary: This point does not need to be tested

Test criteria

Here is what the test criteria include:

  • Function availability - Here, we proceed like a user and check the complete functionality of the app, as well as the logical structure and usability. For instance,

    • Is a general function as described in your extension available?
    • Do the buttons, export, rules, etc., work?
    • Are errors displayed in the console?
  • Lighthouse audit home/listing/detail - We check:

    • If your extension affects the Storefront or not? (so that the search engines have no problems with it).
    • If all buttons, labels, etc., are named correctly?

We pay attention to all five audits. The app must not limit these. Like most search engines, we also pay attention to mobile-first.

Rich snippets have no influence on the ranking of a website. Thus, they do not count among the ranking factors. Nevertheless, search hits enriched with additional information have various SEO advantages: higher attention, higher click-through rate, and greater relevance.

The end customer should not receive any misleading error messages. It does not matter whether a function causes the error or the customer does not use the function correctly. For example, the customer can upload a picture using a function, but if the customer tries to upload a video, a clear message should be displayed here.

  • Cookie check storefront/checkout - Since the GDPR/DSGVO, the classification of cookies is particularly important. We distinguish between three types of cookies.

    • Technically required: Only cookies that are really important for the store without which no purchase would be possible.

    • Comfort functions: Cookies to display personalized ads as banners, newsletter pop-ups, and content from video and social media platforms.

    • Statistics and Tracking: Statistics and everything that has to do with data collection and tracking.

  • Store description German/English - The app store description includes several points if the app can be used only in a specific country, so leave this clearly in the description. The German description is only mandatory if the app is to be offered in the German market. Furthermore, there must always be at least two images of the app in English, e.g., of the Storefront and the Admin.

  • Translations managed admin - We check if the app is available in all languages specified in your account. However, it is important that English is fallback if the app does not support any other language.

  • API validation - If access data is required for the app - for example, an API key; a button must be implemented with which the customer can check the data if this is technically possible.

api access

  • Uninstallation process - During the uninstallation process, the app should be able to uninstall and install without any problems. It is also important to check whether the app depends on other apps and whether they must be uninstalled first.

  • Data will be removed from the database after uninstallation - If the customer selects the option "delete all data" during uninstallation, then all the data has to be removed from the database that was created with the app.

  • Manual code review by a Shopware developer to ensure code quality - This is the last step. A developer looks at the app's code to ensure it is clean and has no security gaps.