Skip to content
Snippets Groups Projects
  1. May 24, 2021
    • Sergey Bronnikov's avatar
      tools: fix script to run jepsen tests · 4fea6bf8
      Sergey Bronnikov authored
      Script used to run Jepsen tests uses Terraform to prepare test environment.
      When I made this script I had a wrong assumption about working directory
      used by Terraform. Due to this sometimes job with Jepsen tests
      failed on cleanup with message:
      
      ```
      Error: Could not load plugin
      
      Plugin reinitialization required. Please run "terraform init".
      
      Plugins are external binaries that Terraform uses to access and manipulate
      resources. The configuration provided requires plugins which can't be located,
      don't satisfy the version constraints, or are otherwise incompatible.
      
      Terraform automatically discovers provider requirements from your
      configuration, including providers used in child modules. To see the
      requirements and constraints, run "terraform providers".
      
      Failed to instantiate provider
      "registry.terraform.io/terraform-providers/openstack" to obtain schema:
      unknown provider "registry.terraform.io/terraform-providers/openstack"
      ```
      
      Terraform documentation describes how Terraform uses working directories [1]
      and there are at least to ways to resolve an issue. First one is using always
      one directory before running terraform subcommands. Second one is using option
      `-chdir` in all terraform commands [2].
      
      1. https://www.terraform.io/docs/cli/init/index.html
      2. https://www.terraform.io/docs/cli/commands/index.html#switching-working-directory-with-chdir
      
      Closes #6089
      4fea6bf8
    • Mergen Imeev's avatar
      box: make UUID part of SCALAR · 5ea50014
      Mergen Imeev authored
      Prior to this patch, UUID was not part of SCALAR. However, this should
      be changed to comply with the RFC "Consistent Lua/SQL types".
      
      Closes #6042
      
      @TarantoolBot document
      Title: UUID is now part of SCALAR
      
      The UUID field type is now part of the SCALAR field type. This means
      that now values of type UUID can be inserted into the SCALAR field, and
      these values can participate in the sorting of the SCALAR fields. The
      order is as follows: boolean < number < string < varbinary < uuid.
      5ea50014
    • Cyrill Gorcunov's avatar
      iproto: stringify IPROTO_RAFT, IPROTO_PROMOTE · 0d090b34
      Cyrill Gorcunov authored
      
      This allows `xlog` Lua module to decode appropriate
      types into symbolic form.
      
      For example with the patch we should see raft and
      promote types in output.
      
       | $ tarantoolctl cat 00000000000000000004.xlog
       | ---
       | HEADER:
       |   lsn: 2
       |   group_id: 1
       |   type: RAFT
       |   timestamp: 1621541912.4588
       | BODY:
       |   0: 3
       |   1: 4
       | ---
       | HEADER:
       |   lsn: 1
       |   replica_id: 4
       |   type: PROMOTE
       |   timestamp: 1621541912.4592
       | BODY:
       |   2: 0
       |   3: 0
       |   83: 3
      
      Fixes #6088
      
      Signed-off-by: default avatarCyrill Gorcunov <gorcunov@gmail.com>
      0d090b34
  2. May 23, 2021
  3. May 20, 2021
  4. May 19, 2021
    • Igor Munkin's avatar
      build: add missing module for jit.dump on ARM64 · 93e2ce52
      Igor Munkin authored
      
      Since commit c9d88d5f ('Fix #984: add
      jit.* library to the binary') all required modules implemented in Lua
      are bundled (i.e. compiled into the executable as a C literal) into
      Tarantool binary. While making Tarantool work on ARM64 platforms, it
      turned out the arch-specific module (namely, jit/dis_arm64.lua) is not
      bundled. Within this patch the missing sources are added and jit.dump
      works fine on ARM64 hosts as a result.
      
      Part of #5983
      Relates to #5629
      Follows up #984
      
      Reviewed-by: default avatarSergey Kaplun <skaplun@tarantool.org>
      Reviewed-by: default avatarSergey Ostanevich <sergos@tarantool.org>
      Signed-off-by: default avatarIgor Munkin <imun@tarantool.org>
      Unverified
      93e2ce52
    • Igor Munkin's avatar
      luajit: bump new version · 3fa165e5
      Igor Munkin authored
      * FFI/ARM64/OSX: Fix vararg call handling.
      * OSX/iOS: Handle iOS simulator and ARM64 Macs.
      * build: pass sysroot to MacOS SDK
      
      Closes #6065
      Closes #6066
      Part of #5629
      Relates to #5983
      Unverified
      3fa165e5
    • Alexander V. Tikhonov's avatar
      github-ci: add result message from coveralls in PR · 660e3263
      Alexander V. Tikhonov authored
      Workflow 'debug_coverage' produces and uploads results to 'coveralls.io'
      web site. Message about it can be shown in PR within each run was done.
      This patch adds the ability to send message in available PR otherwise it
      is skipped. Also added 'coverage.info' file to artifacts list.
      
      Found that used 'coverallsapp/github-action' action checks if the
      trigger was 'pull_request' used to run the workflow [1]. And only in
      this way it writes results message to PR. Previously 'pull_request'
      trigger was blocked to avoid duplication with 'push' trigger. To make
      able to run workflow by any single trigger and to send message to PR
      if it exits, it was implemented the following logic:
      
        - run workflows on both triggers 'push' and 'pull_request';
        - for workflow with 'push' trigger check if PR exists then skip all
          jobs otherwise continue running;
        - for workflow with 'pull_request' trigger continue running;
      
      To avoid of issue coverallsapp/github-action#55 [2], sources checkout
      should be based on 2nd version and later.
      
      Closes #5644
      
      [1]: https://github.com/coverallsapp/github-action/blob/master/src/run.ts#L38
      [2]: https://github.com/coverallsapp/github-action/issues/55#issuecomment-644927165
      660e3263
  5. May 18, 2021
    • Alexander Turenko's avatar
      test: update test-run (fix release_disabled) · 7bee6153
      Alexander Turenko authored
      The problem that is fixed by this test-run update is the following. A
      test that is listed in the 'release_disabled' field in a suite.ini file
      of a 'core = app' or a 'core = unittest' test suite was disabled at all,
      not only for the release tarantool build. A 'core = tarantool' test
      suite was not affected by the problem.
      
      Disabled sql-tap/debug_mode_only.test.lua test, because it does not work
      anymore. We plan to revisit this test in the scope of #3694.
      
      See https://github.com/tarantool/test-run/issues/199
      Unverified
      7bee6153
  6. May 17, 2021
  7. May 14, 2021
  8. May 13, 2021
    • Serge Petrenko's avatar
      recovery: make it yield when positioning in a WAL · 17289440
      Serge Petrenko authored
      We had various places in box.cc and relay.cc which counted processed
      rows and yielded every now and then. These yields didn't cover cases,
      when recovery has to position inside a long WAL file:
      
      For example, when tarantool exits without leaving an empty WAL file
      which will be used to recover instance vclock on restart. In this case
      the instance freezes while processing the last available WAL in order
      to recover the vclock.
      
      Another issue is with replication. If a replica connects and needs data
      from the end of a really long WAL, recovery will read up to the needed
      position without yields, making relay disconnect by timeout.
      
      In order to fix the issue, make recovery decide when a yield should
      happen. Once recovery decides so, it calls a xstream callback,
      schedule_yield. Currently schedule_yield is fired once recovery
      processes (either skips or writes) WAL_ROWS_PER_YIELD rows.
      
      schedule_yield either yields right away, in case of relay, or saves the
      yield for later, in case of local recovery, because it might be in the
      middle of a transaction.
      
      Closes #5979
      17289440
  9. May 04, 2021
  10. Apr 30, 2021
  11. Apr 28, 2021
    • Vladislav Shpilevoy's avatar
      txn: destroy commit and rollback triggers · 7fd53b4c
      Vladislav Shpilevoy authored
      They were not deleted ever. Worked fine for DDL and replication,
      for which they were introduced in the first place, because these
      triggers are on the region memory.
      
      But didn't work when the triggers became available in the public
      API, because these are allocated on the heap. As a result, all the
      box.on_commit() and box.on_rollback() triggers leaked.
      
      The patch ensures all the on_commit/on_rollback triggers are
      destroyed.
      
      The statement triggers on_commit/on_rollback are left intact since
      they are private and never need deletion, but the patch adds
      assertions in case they ever would need to be destroyed.
      
      Another option was to force all the commit and rollback triggers
      clear themselves. For example, in case of commit all the on_commit
      triggers must clear themselves, and the rollback triggers are
      destroyed. Vice versa when a rollback happens. This would allow
      not to manually destroy on_commit triggers in case of commit. But
      it didn't work because the Lua triggers all work via a common
      runner lbox_trigger_run(), which can't destroy its argument in
      most of the cases (space:on_replace, :before_replace, ...). It
      could be patched but requires to add some work to the Lua triggers
      affecting all of them, which in total might be not better.
      
      Closes #6025
      7fd53b4c
  12. Apr 27, 2021
    • HustonMmmavr's avatar
      test: fix regex in box-py/args.test.py · f44663ed
      HustonMmmavr authored
      Regex for validating version was expecting a single
      character (digit) for version `patch`, but it's not correct.
      This patch fixes test behaviour for tarantool 1.10.10
      
      Close #6039
      f44663ed
    • Vladislav Shpilevoy's avatar
      fiber: use wakeup safely on self everywhere · 8d1ebd83
      Vladislav Shpilevoy authored
      The previous commit made fiber_wakeup() safe to use on the current
      fiber. Leverage the new behaviour everywhere in the source code to
      remove all checks f != fiber() before fiber_wakeup(f) calls.
      
      Follow-up #5292
      8d1ebd83
    • Vladislav Shpilevoy's avatar
      fiber: make wakeup in Lua and C nop on self · db0ded5d
      Vladislav Shpilevoy authored
      fiber.wakeup() in Lua and fiber_wakeup() in C could lead to a
      crash or undefined behaviour when called on the currently running
      fiber.
      
      In particular, if after wakeup was started a new fiber in a
      blocking way (fiber.create() and fiber_start()) it would crash in
      debug build, and lead to unknown results in release.
      
      If after wakeup was made a sleep with non-zero timeout or an
      infinite yield (fiber_yield()), the fiber woke up in the same
      event loop iteration regardless of any timeout or other wakeups.
      It was a spurious wakeup, which is not expected in most of the
      places internally.
      
      The patch makes the wakeup nop on the current fiber making it safe
      to use anywhere.
      
      Closes #5292
      Closes #6043
      
      @TarantoolBot document
      Title: fiber.wakeup() in Lua and fiber_wakeup() in C are nop on self
      In Lua `fiber.wakeup()` being called on the current fiber does not
      do anything, safe to use. The same for `fiber_wakeup()` in C.
      db0ded5d
    • Cyrill Gorcunov's avatar
      wal: sanitize wal_mode · 5bd34c97
      Cyrill Gorcunov authored
      
       - add comments about modes
       - there is no need to carry NULL in wal_mode_STRS
       - use designated assignment in wal_mode_STRS
      
      Acked-by: default avatarSerge Petrenko <sergepetrenko@tarantool.org>
      Acked-by: default avatarVladislav Shpilevoy <v.shpilevoy@tarantool.org>
      Signed-off-by: default avatarCyrill Gorcunov <gorcunov@gmail.com>
      5bd34c97
  13. Apr 26, 2021
  14. Apr 22, 2021
    • Oleg Babin's avatar
      digest: introduce FFI bindings for xxHash32/64 · f998ea39
      Oleg Babin authored
      This patch introduces new hash types for digest module - xxHash32
      and xxHash64.
      
      Closes #2003
      
      @TarantoolBot document
      Title: digest module supports xxHash32/64
      
      ```lua
      -- Examples below demonstrate xxHash32.
      -- xxHash64 has exactly the same interface
      
      -- Calculate the 32-bits hash (default seed is 0).
      digest.xxhash32(string[, seed])
      
      -- Streaming
      -- Start a new hash by initializing state with a seed.
      -- If no value provided, 0 is used as default.
      xxhash = digest.xxhash32.new([seed])
      -- Also it's possible to specify seed manually. If no value
      -- provided a value initially passed to "new" is used.
      -- Here and below "seed" expected to be unsigned
      -- number. Function returns nothing.
      xxhash:clear([seed])
      -- Feed the hash state by calling "update" as many times as
      -- necessary. Function returns nothing.
      xxhash:update('string')
      -- Produce a hash value.
      xxhash:result()
      ```
      f998ea39
    • Oleg Babin's avatar
      digest: eliminate excess table lookup · 2f1df7eb
      Oleg Babin authored
      This patch removes excess table lookup for FFI calls. So we save
      one hash operation and do it in mannier that used for another
      modules such as "tuple", "uuid", etc.
      
      For details see [1] section "To Cache or Not to Cache".
      
        [1] https://luajit.org/ext_ffi_tutorial.html
      2f1df7eb
  15. Apr 21, 2021
Loading