Skip to content

Conversation

@tatchi
Copy link
Contributor

@tatchi tatchi commented Oct 29, 2024

This is based on #60

I've added some tests in this PR related to integer encoding, to demonstrate the range of values supported, and to start a discussion on how to support 64-bit integer encoding.

As you can see from the tests, the current maximun supported value is Int32.max_int. Trying to insert e.g a Unsigned.UInt32.max_int value to an integer unsigned column or a Int.max_int to a bigint column fails.

I ran the same tests (in this branch) where I included #54. In this case, the maximum value is Int.max_int and both examples above works fine. It still doesn't support 64 bits integer though.

So I finally tested it against #43. I was able to insert (and read back) both Int64.max_int and Unsigned.UInt64.max_int (see commit). Unfortunately, it breaks two other tests:

test_txn

((2024-10-29 16:15:29.793594000+01:00)
 ("unhandled exception"
  ((monitor.ml.Error
    (Failure "field 'CAST(sum(i) AS integer)' is not an integer")
    ("Raised at Stdlib.failwith in file \"stdlib.ml\", line 29, characters 17-33"
     "Called from Nonblocking_testsuite.Make.test_txn.(fun) in file \"tests/nonblocking/nonblocking_testsuite.ml\", line 199, characters 36-55"
     "Called from Async_kernel__Deferred0.bind.(fun) in file \"src/deferred0.ml\", line 54, characters 64-69"
     "Called from Async_kernel__Job_queue.run_jobs in file \"src/job_queue.ml\", line 180, characters 6-47"
     "Caught by monitor main"))

test_many_select

Parameter (609520357 : int) came back as (609520357 : int64).

I don't know much about the low level C code, but from an end user perspective I'd say that:

paurkedal and others added 5 commits October 17, 2024 12:34
The existing "stress tests" forms the initial test suite, while the
remaining executables, which takes an extra OCAML_MARIADB_QUERY
environment variable, are considered examples.
The blocking tests were duplicates of corresponding non-blocking tests.
This commit replaces it with a merged concurrency-less main which
instantiates the test suite twice, once using the blocking API and once
using the non-blocking API.
@tatchi tatchi requested a review from ygrek as a code owner October 29, 2024 15:18
@paurkedal
Copy link
Collaborator

I agree, and the additional tests will be very useful.

@paurkedal paurkedal merged commit 7770c95 into ocaml-community:master Nov 13, 2024
paurkedal added a commit to paurkedal/opam-repository that referenced this pull request Nov 28, 2024
CHANGES:

  - Added `Stmt.start_txn` (ocaml-community/ocaml-mariadb#59 by Corentin Leruth).
  - Added `Res.insert_id` as binding for `mysql_stmt_insert_id` (ocaml-community/ocaml-mariadb#58 by
    Corentin Leruth).
  - Updated to support recent OCaml versions (ocaml-community/ocaml-mariadb#45 by @kit-ty-kate).
  - Fixed too-early retrieval of statement metadata (ocaml-community/ocaml-mariadb#41 by Albert Peschar).
  - Fixed decoding bug for the integer type (ocaml-community/ocaml-mariadb#54 by Raman Varabets, tested
    by ocaml-community/ocaml-mariadb#61 by Corentin Leruth).
  - Fixed a memory leaks related to result metadata (ocaml-community/ocaml-mariadb#39 by Albert Peschar).
  - The build system is now dune and dune-configurator (ocaml-community/ocaml-mariadb#52 by Petter A.
    Urkedal) and some of the examples have been converted to a test suite
    (ocaml-community/ocaml-mariadb#60 by Petter A. Urkedal).
  - The project has been transferred to ocaml-community with Petter A.
    Urkedal as the new maintainer.
paurkedal added a commit to paurkedal/opam-repository that referenced this pull request Nov 28, 2024
CHANGES:

  - Added `Stmt.start_txn` (ocaml-community/ocaml-mariadb#59 by Corentin Leruth).
  - Added `Res.insert_id` as binding for `mysql_stmt_insert_id` (ocaml-community/ocaml-mariadb#58 by
    Corentin Leruth).
  - Updated to support recent OCaml versions (ocaml-community/ocaml-mariadb#45 by @kit-ty-kate).
  - Fixed too-early retrieval of statement metadata (ocaml-community/ocaml-mariadb#41 by Albert Peschar).
  - Fixed decoding bug for the integer type (ocaml-community/ocaml-mariadb#54 by Raman Varabets, tested
    by ocaml-community/ocaml-mariadb#61 by Corentin Leruth).
  - Fixed a memory leaks related to result metadata (ocaml-community/ocaml-mariadb#39 by Albert Peschar).
  - The build system is now dune and dune-configurator (ocaml-community/ocaml-mariadb#52 by Petter A.
    Urkedal) and some of the examples have been converted to a test suite
    (ocaml-community/ocaml-mariadb#60 by Petter A. Urkedal).
  - The project has been transferred to ocaml-community with Petter A.
    Urkedal as the new maintainer.
paurkedal added a commit to paurkedal/opam-repository that referenced this pull request Nov 29, 2024
CHANGES:

  - Added `Stmt.start_txn` (ocaml-community/ocaml-mariadb#59 by Corentin Leruth).
  - Added `Res.insert_id` as binding for `mysql_stmt_insert_id` (ocaml-community/ocaml-mariadb#58 by
    Corentin Leruth).
  - Updated to support recent OCaml versions (ocaml-community/ocaml-mariadb#45 by @kit-ty-kate).
  - Fixed too-early retrieval of statement metadata (ocaml-community/ocaml-mariadb#41 by Albert Peschar).
  - Fixed decoding bug for the integer type (ocaml-community/ocaml-mariadb#54 by Raman Varabets, tested
    by ocaml-community/ocaml-mariadb#61 by Corentin Leruth).
  - Fixed a memory leaks related to result metadata (ocaml-community/ocaml-mariadb#39 by Albert Peschar).
  - The build system is now dune and dune-configurator (ocaml-community/ocaml-mariadb#52 by Petter A.
    Urkedal) and some of the examples have been converted to a test suite
    (ocaml-community/ocaml-mariadb#60 by Petter A. Urkedal).
  - The project has been transferred to ocaml-community with Petter A.
    Urkedal as the new maintainer.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants