title |
---|
Quality assurance |
Datagrok is an incredibly powerful platform. To give users the best possible performance, we have created a number of unique, proprietary technologies, such as in-memory columnar database and fast visualizations. To provide the seamless end-to-end-experience, we took ownership of data access, data governance, data exploration, scientific computing,machine learning and artificial intelligence, and collaboration. To make sure our enterprise customers can work with their data in a secure and efficient manner, we have built features like authentication, audit. The list goes on and on.
This sort of power comes at the cost of significantly increasing the platform's complexity. And our QA processes, along with the CI/СD concept, maintain the reliability and functionality of platform core and external systems that we integrate with dependencies and interactions they bring.
To ensure quick and reliable code delivery, we apply the CI/CD flow using the following tools:
- We use Git as a VCS, and we follow the versioning policy for Datagrok JS APIs, packages, libraries, and Docker images.
- Jenkins automates the process of building and testing code every time a change
is made to the codebase in Git. It automatically executes the following tasks:
- Static code analysis by dartanalyzer
- Unit tests
- Compilation
- Packaging the platform in Docker containers
- Snyk and Grype check for vulnerabilities
- Docker Hub stores built artifacts, such as compiled code and packages that are generated during the build process.
- Ansible automates the process of provisioning and configuring servers for deployment.
- We use Docker to run platform versions in isolated environments for
automated and manual testing while
deploying releases. Every time a docker image is built, the following tasks get
executed:
- Deploying the server on dev environment
- Integration tests
- API and UI Tests
- Package Tests
- Performance benchmarks
- Docker Swarm, AWS ECS, and K8S are our orchestration tools for the deployment and scaling of containers.
- We use Prometheus to track the performance and behavior of applications in production.
With the help of CI/CD, automated testing is performed on code changes as they are integrated. We also run automated tests every hour on our instances and encourage developers to use them when performing local package testing. All the results of the automated tests are kept in the test tracking system.
There are several types of automated tests that we use:
- Unit tests. Our core libraries contain over 2,000 unit tests that execute automatically in the continuous integration process, enabling us to detect regression bugs.
- Integration tests. These tests cover interactions between different modules, while unit tests tend to address isolated modules.
- JS API tests. We have a regular Datagrok package containing a suite of tests for the JS API. These tests are executed automatically on a server using a headless browser mode.
- UI tests. We have over 100 complex UI tests for automated testing of the platform. Each test is associated with a separate story, which describes the intended objective, actions, and expected outcome of the user. To emulate user input, we use Selenium. It also checks the expected result.
- Package tests. These tests include unit tests and function tests. We provide function tests for packages, scripts, and APIs, as they all utilize the concept of functions.
- Performance benchmarks. We run performance benchmarks as part of the build and keep track of the results to ensure that the platform only gets better with time.
- Stress tests. To ensure that the platform is stable under heavy load, we perform automated stress testing regularly. The real workflow is emulated by spawning many virtual machines that have Selenium installed on them and executing selected UI tests on them. This helps us identify steps responsible for the performance degradation. For more details on different environments, tests, and interpretation of results, see stress testing results.
We use smoke tests and structured tests for complex scenarios in two primary cases:
- Testing new or fixed functionality. Whenever new functionality is developed or existing functionality is modified, the QA engineer executes test cases that validate the expected behavior of the software. This testing ensures that the functionality is working as expected and any defects found are logged and fixed before the release of the software.
- Release testing Before the software is released, the QA engineer executes a comprehensive set of test cases to ensure the software is ready for release and meets the specified quality standards.
We work on a reliable process to identify and address issues promptly. At Datagrok, we have multiple sources of getting feedback, and we track issues that we achieve from our clients through emails, Teams, meetings, and clients' QA. Additionally, we use manual tests, automatic tests, monitoring and logging systems, and our community to gather feedback and identify issues.
You can report an issue directly in one of our issue tracking systems. We use JIRA for internal issues, integrated with BitBucket, and GitHub Tracker for all externally reported issues. We recommend reporting issues in JIRA if you have access to it, but if you don't, use GitHub Tracker.
Tracking the issues, we stay on top of the platform's current status, including critical issues, promised features, and upcoming changes. You can also track our latest updates in Release notes.
Is an integrated monitoring system that runs automated package tests every hour. It's also possible to run package testing locally before publishing.
To monitor the results of test execution, we have developed a unique application on top of the Datagrok platform. This application visualizes the application's current state and enables QA engineers promptly access, execute, and report the completion status of stories. Additionally, it lets us quickly navigate to the corresponding JIRA issues as we have integrated JIRA with Datagrok's OpenAPI capabilities.
Test Manager is a tool within the Datagrok platform that provides a convenient interface for selecting and running package unit tests with additional capabilities for exploring the test results. Test manager is a component of the DevTools package. See Test Manager to learn more.
Usage Analysis is the Datagrok package that facilitates understanding of Datagrok platform usage through different viewers, displaying data on usage statistics, errors, and platform events. See Usage Analysis to learn more.
Errors encountered by users
See also: