druid/quidem-ut/README.md

75 lines
2.7 KiB
Markdown
Raw Normal View History

2024-06-20 10:21:56 -04:00
<!--
~ Licensed to the Apache Software Foundation (ASF) under one
~ or more contributor license agreements. See the NOTICE file
~ distributed with this work for additional information
~ regarding copyright ownership. The ASF licenses this file
~ to you under the Apache License, Version 2.0 (the
~ "License"); you may not use this file except in compliance
~ with the License. You may obtain a copy of the License at
~
~ http://www.apache.org/licenses/LICENSE-2.0
~
~ Unless required by applicable law or agreed to in writing,
~ software distributed under the License is distributed on an
~ "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
~ KIND, either express or implied. See the License for the
~ specific language governing permissions and limitations
~ under the License.
-->
2024-06-18 09:07:48 -04:00
# Quidem UT
2024-06-18 09:07:48 -04:00
Enables to write sql level tests easily.
2024-08-05 10:23:54 -04:00
Can be used to write tests against existing test backends (ComponentSupplier) - by doing so the testcases can be moved closer to the exercised codes.
2024-06-18 09:07:48 -04:00
## Usage
2024-06-20 13:45:01 -04:00
### Install java&maven (if needed)
If you don't have java&maven - one way to set that up is by using sdkman like this:
2024-07-18 03:06:59 -04:00
```bash
2024-06-20 13:45:01 -04:00
# install sdkman
curl -s "https://get.sdkman.io" | bash
# at the end of installation either open a new terminal; or follow the instructions at the end
# install java&maven
sdk install java 11.0.23-zulu
sdk install maven
# run mvn to see if it works
mvn --version
2024-08-05 10:23:54 -04:00
# download druid sources
git clone https://github.com/apache/druid
2024-06-20 13:45:01 -04:00
```
2024-06-18 12:33:22 -04:00
### Running these tests
2024-06-18 09:07:48 -04:00
* CI execution happens by a standard JUnit test `QTest` in this module
* the `dev/quidem` script can be used to run these tests (after the project is built)
2024-06-18 12:33:22 -04:00
### Launching a test generating broker
2024-06-18 09:07:48 -04:00
* make sure to build the project first; one way to do that is:
2024-07-18 03:06:59 -04:00
```bash
mvn install -pl quidem-ut/ -am -DskipTests -Pskip-static-checks
2024-06-18 09:07:48 -04:00
```
* launch the broker instance with:
2024-07-18 03:06:59 -04:00
```bash
mvn exec:exec -pl quidem-ut -Dquidem.record.autostart=true
2024-06-18 09:07:48 -04:00
```
2024-06-18 12:33:22 -04:00
* the broker will be running at http://localhost:12345
* the used test configuration backend can configured by supplying `quidem.uri`
2024-07-18 03:06:59 -04:00
```bash
mvn exec:exec -pl quidem-ut -Dquidem.uri=druidtest:///?componentSupplier=ThetaSketchComponentSupplier
2024-06-18 12:33:22 -04:00
```
* new record files can be started by calling http://localhost:12345/quidem/start
2024-06-18 12:43:10 -04:00
* if `quidem.record.autostart` is omitted recording will not start
2024-06-18 12:33:22 -04:00
* after finished with the usage of the broker ; a new `record-123.iq` file will be in the project's worktree - it will contain all the executed statements
2024-06-20 13:45:01 -04:00
* running `dev/quidem -Dquidem.overwrite` updates the resultsets of all `iq` files around there
2024-06-18 12:43:10 -04:00
* rename the testfile to have a more descriptive name
2024-06-18 09:07:48 -04:00