Skip to content

Latest commit

 

History

History
315 lines (234 loc) · 15 KB

CHANGELOG.md

File metadata and controls

315 lines (234 loc) · 15 KB

Changelog

[1.8.7] - 2023-07-20

  • Introduce --schema-seed (#376)
  • Make --seed and --schema-seed random by default (#394)
  • Expand types allowed in partition key by schema generator (#394)
  • Queries to test and oracle are running in parallel (#375)
  • Fix time generator to match general gocql limitations (#389)
  • Make maps to work again (#392)
  • Fix values circulation - (#390) and (#397)
  • Check on inflights conflict early - (#399)

[1.8.6] - 2023-07-06

  • Test stops after warmup (9aa8f65)
  • Make goreleaser work after deprication of replacements (99ddf27)

[1.8.5] - 2023-07-05

  • Set oracle timeout properly (3e8f096)
  • Update gocql to 1.8.0 (6bbb4fb)
  • Gemini can get stuck at the end of test (#372)

[1.8.4] - 2023-06-20

  • Populate version info (#361)
  • Fix false-positives when test cycle is getting terminated (#363)
  • Fix schema loading to support complex types (#360)

[1.8.3] - 2023-06-15

  • Pause generator when partitions are full (#332)
  • Fix TYPE_TIME value generations (#337)
  • Make validation retry on SelectFromMaterializedViewStatementType (#347)
  • Make gemini avoid running DROP COLUMN when it is not suppported (#350)
  • Fix UDT value generations (357)

[1.8.2] - 2023-06-01

  • Redo jobs execution: warm up and work cycles execution should be clear and predictable (#310)
  • Use request-timeout parameter for Oracle (#323)
  • Speedup random string generation (#325)
  • Implement statement cache (#328)

[1.8.1] - 2023-05-15

  • Fix value corruption (#318)
  • Make gemini work properly when min=max (#317)
  • Fix pk values spoiling (#314)
  • Fix lt function have wrong compare for big.Int (#311)
  • Reduce memory allocations (#308)
  • Reduce inflight shrinking limit (#306)
  • Fix gemini table data corruption on DDL statement execution error (#305)
  • Package reorganization (#303)
  • Use atomic global status instead of channel pipeline (#301)
  • Delivery values and partition range config as pointers (#299)
  • Added soft stop (#297)

[1.8.0] - 2023-05-03

  • Update packages and golang (#296)
  • Fix(inflight): reduce memory footprint by using struct{} instead of bool (#291)
  • Fix warmup hunging (#292)

[1.7.9] - 2023-04-25

[1.7.8] - 2023-02-02

  • Fix issue: memory leak due golang maps are not shrinking when you do delete on them (#267)

[1.7.7] - 2022-08-24

  • Fix issue: max-partition-keys should align with Scylla's --max-partition-key-restrictions-per-query and --max-clustering-key-restrictions-per-query configuration options(#271)
  • Fix issue: wrong number of values passed to prepared select query (272)
  • Fix issue: Gemini issues a query involved with data filtering without using ALLOW FILTERING and thus may have unpredictable performance (273)
  • Support request and connection timeout. Could be set via cli parameters

[1.7.6] - 2022-08-03

Fixed

  • fixed error handling in load function

[1.7.6] - 2022-08-03

Fixed

  • fixed error handling in load function

[1.7.5] - 2021-04-28

Fixed

  • Fix materialized view creation if the view already exists.

[1.7.4] - 2021-01-04

Added

  • Print errors to standard out to debug cases where Gemini detects an error but no error log is generated.

1.7.3 - 2020-09-21

Added

  • Add options to choose host selection policy.
  • Add option to use server-side timestamps for queries.
  • Add support for password authentication.

Fixed

  • Don't enable tracing if it's not requested.
  • schema: add "IF NOT EXISTS" check when creating a new type
  • Avoid DDL operations for a table with MV (#198)
  • Add support for generating multiple tables in schema with the --max-tables command line option.

1.6.0 - 2019-09-06

  • Bumped driver version to v1.3.0-rc.1
  • Lazy partition key generation reintroduced to avoid out of memory issues. This brings in a new CLI arg --token-range-slices that defines how many slices the partition keyspace should be divided into when applying the different distribution functions. The default value of this is set to an ad-hoc value of 10000 which should supply ample possibilities for varying selection of values according to the chosen probability distribution.

1.5.0 - 2019-08-26

  • Fix overlapping operations on the same partition key (#198).
  • Partition keys can now be drawn from various distributions such as "zipf", "uniform" and "normal". The CLI argument --partition-key-distribution is used to select which distribution to use. The default is normal.
  • The CLI argument partition-key-buffer-size is removed since it carries no meaning any more.
  • Added the possibility to run without any validations against the Oracle. Simply do not supply a host for the Oracle and Gemini will assume you want to only run against Test.
  • Replication strategy is now configurable via the CLI argument --replication-strategy.

1.4.4

  • Mutations on Test are only applied if they first succeeded on the Oracle.

1.4.3

  • Bugfix that makes sure that when a job terminates early, the result status is properly sent to the collector.
  • Gemini ensures that material views can be created in the default case by simply creating enough keys and columns.

1.4.2

  • Reused primary keys does no longer block the caller if none are available.
  • Primary key generation no longer blocks if the targeted source is full.
  • Upgraded driver to 1.2.0

v1.4.1

  • Bug in shutdown handling that caused deadlock is fixed.
  • Index queries reapplied with low frequency for certain types.
  • Fix for invalid materialized view ddl statement.

1.4.0

  • A source concept is used to coordinate the creation, consumption and reuse of partition keys.
  • Two new CLI args are introduced to control the buffer sizes of the new and reusable partition keys partition-key-buffer-size and partition-key-buffer-reuse-size.
  • The CLI arg concurrency now means the total number of actors per job type. You may need to scale down your settings for this argument since for example a mixed mode execution will run with twice as many goroutines. Experimentation is encouraged since a high number will also yield much greater throughput.

1.3.4

  • Shutdown is no longer waiting for the warmup phase to complete.
  • Partition keys can now be any supported type.
  • The size of the partition key buffers can be configured on the commandline through partition-key-buffer-size and partition-key-buffer-reuse-size.

1.3.0

  • Partitioning bewteen workers are now handled by a generator that generates random partition keys and dispatches them to the relevant worker. This construct also provides a channel for "old" values to be used downstream by validators. The reason for this is that if the validators read newly created partition keys then the chances of finding data in the database is near to zero unless we load it up with a truly huge data set.
  • Log levels introduced and configured via CLI arg level. Common values such as info, debug and error are supported.
  • Mutations are now retried at a considerably greater number of times than reads. The number of retries and the time between them are configure via --max-mutation-retries and --max-mutation-retries-backoff.

1.2.0 - 2019-06-20

  • DDL statements are now emitted with low frequency if the --cql-features is set to at least "all" level.
  • Data sizes are configurable though a CLI argument --dataset-size and the currently supported values are "small" and "large".
  • CLI toggle --cql-features added to let the user select which type of CQL features to use. The current levels are basic, normal and all. The basic level have only regular columns and no indexes nor materialized views. normal adds these two constructs and all currently the same as normal but will be used to differentiate more advanced features in the future.

1.1.0 - 2019-06-11

  • Exponential backoff retry policy added with 5 retries between 1 and 10 seconds.
  • Support for changing consistency level via a CLI argument consistency.
  • Support for compaction strategies added via a CLI argument compaction-strategy as a set of string values "stcs", "twcs" or "lcs" which will make Gemini choose the default values for the properties of the respective compaction strategies. Alternatively the JSON-like definition of the compaction-strategy can be supplied in a form like: {"class"="SizeTieredCompactionStrategy", "enabled"=true, ....}. Note that the form needs to be given as actual valid JSON.
  • Prometheus metrics added that exposes internal runtime properties as well as counts fo CQL operations 'batch', 'delete', 'insert', 'select' and 'update'.
  • Warmup duration added during which only inserts are performed.
  • Generating valid single index queries when a complex primary key is used.
  • Gracefully stopping on sigint and sigterm.
  • JSON marshalling of Schema fixed. The schema input file has changed to ensure marshalling of lists and sets. These types now have a kind property with possible values (list,set).
  • Correctly pretty printing map and UDT types.
  • Skipping HTML escaping of resulting JSON.
  • Ensure proper termination when errors happen.
  • Fix mutation timestamps to match on system under test and test oracle.
  • Gemini now tries to perform mutation on both systems regardless of if one of them fail.
  • Gemini now timestamps errors for easier correlation.
  • A new Store abstraction is introduced in preparation to enable implementations such as an in-memory store.
  • Gemini now uses github.com/scylladb/gocqlx/qb builder.
  • Gemini ensures that primary key buckets do not overflow int32.
  • Gemini now accepts a list of node host names or IPs for the test and Oracle clusters.
  • Default maximum primary keys increased to MAX_INT32/concurrency.
  • Range tombstones are being generated.

1.0.0 - 2019-05-06

  • Gemini version is now available in the resulting output.
  • Materialized Views support.
  • Improved error handling in validation code.
  • Avoiding small double booking of write ops in case of mutation errors.
  • Printing executable CQL statements when logging errors or in verbose mode.
  • JSON schema definition file has simpler index definition.

0.9.2 - 2019-04-18

  • Support for User Defined Types (UDT) added for simple columns.
  • Support for collections such as sets, lists and maps added for simple columns.
  • Support for writing the result to a file in JSON format.

0.9.1 - 2019-04-11

Added

  • Tuple support added for simple columns.
  • Added version info printing using '--version' program argument.
  • CQL INSERT JSON statement support.

Fixed

  • Panic when --non-interactive command line option is passed (#69)

0.9.0 - 2019-04-03

Added

  • Support for queries using secondary indexes added.
  • Switched to using the upstream Go driver https://github.com/scylladb/gocql instead of the regular driver. The goal is performance gains by using that shard awareness feature as well as providing proper more real testing of the driver.
  • Support for additional types for the clustering keys. TimeUUID is used runtime to accomplish sorted UUIDs. Blob, text and varchar types are based on ksuid to be sortable.
  • Launcher script (scripts/gemini-launcher) that starts an Apache Cassandra node as the test oracle and a Scylla node as the system under test using Docker.
  • Schema generation support. Gemini generates a random schema unless user specifies one with the --schema command line option.

Changed

  • Improve progress indicator (#14).