Skip to content
Snippets Groups Projects
This project is mirrored from https://github.com/metabase/metabase. Pull mirroring updated .
  1. Aug 16, 2022
  2. Aug 15, 2022
  3. Aug 12, 2022
    • Cam Saul's avatar
      Enable Kondo for tests part 2: enable `:unused-binding` linter and fix warnings (#24748) · adf45182
      Cam Saul authored
      * Fix some small things
      
      * Add Kondo to deps.edn to be able to debug custom hooks from REPL
      
      * Fix macroexpansion hook for with-temp* without values
      
      * Test config (WIP)
      
      * More misc fixes
      
      * Disable :inline-def for tests
      
      * More misc fixes
      
      * Fix $ids and mbql-query kondo hooks.
      
      * Fix with-temporary-setting-values with namespaced symbols
      
      * More misc fixes
      
      * Fix the rest of the easy ones
      
      * Fix hook for mt/dataset
      
      * Horrible hack to work around https://github.com/clj-kondo/clj-kondo/issues/1773 . Custom linter for mbql-query macro
      
      * Fix places calling mbql-query with a keyword table name
      
      * Fix the last few errors in test/
      
      * Fix errors in enterprise/test and shared/test
      
      * Fix driver test errors
      
      * Enable linters on CI
      
      * Enable unresolved-namespace linter for tests
      
      * Appease the namespace linter again
      
      * Test fixes
      
      * Enable unused-binding linter for test/ => 293 warnings
      
      * 259 warnings
      
      * 234 warnings
      
      * => 114 warnings
      
      * Fix the rest of the unused binding warnings in test/
      
      * Fix unused binding errors in enterprise/backend/test
      
      * Fix unused binding lint errors in driver tests
      
      * Test fix :wrench:
      
      * Assure Kondo that something is in fact used
      Unverified
      adf45182
    • Cam Saul's avatar
      Enable Kondo for tests (part 1) (#24736) · bc4acbd2
      Cam Saul authored
      * Fix some small things
      
      * Add Kondo to deps.edn to be able to debug custom hooks from REPL
      
      * Fix macroexpansion hook for with-temp* without values
      
      * Test config (WIP)
      
      * More misc fixes
      
      * Disable :inline-def for tests
      
      * More misc fixes
      
      * Fix $ids and mbql-query kondo hooks.
      
      * Fix with-temporary-setting-values with namespaced symbols
      
      * More misc fixes
      
      * Fix the rest of the easy ones
      
      * Fix hook for mt/dataset
      
      * Horrible hack to work around https://github.com/clj-kondo/clj-kondo/issues/1773 . Custom linter for mbql-query macro
      
      * Fix places calling mbql-query with a keyword table name
      
      * Fix the last few errors in test/
      
      * Fix errors in enterprise/test and shared/test
      
      * Fix driver test errors
      
      * Enable linters on CI
      
      * Enable unresolved-namespace linter for tests
      
      * Appease the namespace linter again
      
      * Test fixes
      Unverified
      bc4acbd2
    • Ryan Laurie's avatar
      Refactor Filter Popover to functional component (#24729) · e474b0aa
      Ryan Laurie authored
      * refactor FilterPopover to functional component
      Unverified
      e474b0aa
    • Aleksandr Lesnenko's avatar
      fix reset password flow (#24731) · afa548bc
      Aleksandr Lesnenko authored
      * fix reset password flow
      
      * review
      Unverified
      afa548bc
    • Alexander Polyankin's avatar
    • Dalton's avatar
      Retrieve field metadata from cached card object when a dimension has a virtual card table (#24645) · 0646a3e5
      Dalton authored
      * Add cards to the metadata godhead
      
      * Use source query result_metadata when calling fieldDimension.field()
      
      * Various unit test fixes
      
      * First pass at attempting to refactor fields method
      
      * Round 2: more aggressive refactor...
      
      * Third pass, improved comments + minor tweaks
      
      * Add unit tests for more scenarios
      
      * Remove metadata from cards in normalization fn
      
      * Fix broken tests
      
      * Separate field logic for int id fields and non-int id fields
      
      * Remove usage of old metadata.question method
      
      * Limit some logic to datsets/models
      
      * Don't default objects arg of copyObjects
      
      * Add instantiateQuestion unit test
      
      * revert unit test that no longer needs fixing
      
      * Dimension tweaks
      
      * fix unit test fixture
      Unverified
      0646a3e5
  4. Aug 11, 2022
    • Case Nelson's avatar
      [Actions] Add emitter-usages hydration (#24640) · b4033491
      Case Nelson authored
      * Move writeback migrations to 45
      
      * Empty commit to trigger GitHub Actions
      
      * [Actions] Simplify emitter schema model
      
      emitter_action was dropped since emitters just have a singular action
      and the join table was unecessary.
      
      emitter_action.action_id columns moved onto emitter table.
      
      Dropped CardEmitter and DashboardEmitter pre-insert, pre-update,
      pre-delete since they were used in tests only and normal operation
      would see the emitter inserted first.
      
      Since previous code may have 'orphaned' emitters without an action, we
      delete emitters without action to be safe.
      
      * Handle flakiness with geojson java.net.UnknownHostException errors (#24523)
      
      * Handle flakiness with geojson java.net.UnknownHostException errors
      
      In CI seems like we are getting errant errors:
      
      ```clojure
      geojson.clj:62
      It validates URLs and files appropriately
      http://0xc0000200
      expected: (valid? geojson)
        actual: #error {
       :cause "Invalid IP address literal: 0xc0000200"
       :via
       [{:type clojure.lang.ExceptionInfo
         :message "Invalid GeoJSON file location: must either start with http:// or https:// or be a relative path to a file on the classpath. URLs referring to hosts that supply internal hosting metadata are prohibited."
         :data {:status-code 400, :url "http://0xc0000200"}
         :at [metabase.api.geojson$valid_url_QMARK_ invokeStatic "geojson.clj" 62]}
        {:type java.net.UnknownHostException
         :message "0xc0000200"
         :at [java.net.InetAddress getAllByName "InetAddress.java" 1340]}
        {:type java.lang.IllegalArgumentException
         :message "Invalid IP address literal: 0xc0000200"
         :at [sun.net.util.IPAddressUtil validateNumericFormatV4 "IPAddressUtil.java" 150]}]
      ```
      
      Not clear if this change has a hope of fixing it: if it doesn't resolve
      once its possible it is cached somewhere in the network stack, or it
      won't resolve if you ask again.
      
      But gonna give it a shot.
      
      Set the property `"networkaddress.cache.negative.ttl"` to `"0"`
      
      > networkaddress.cache.negative.ttl (default: 10)
      >    Indicates the caching policy for un-successful name lookups from the name service. The value is specified as an integer to indicate the number of seconds to cache the failure for un-successful lookups.
      
      >    A value of 0 indicates "never cache". A value of -1 indicates "cache forever".
      
      From
      https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/net/InetAddress.html
      
      
      in the hopes that we can try multiple times. Restores the original value
      after the test completes so we don't inadvertently change behavior
      elsewhere.
      
      If we get an error of java.net.UnknownHostException we try again if we
      have attempts remaining. If we get a boolean it means the ip resolution
      worked so we can rely on the response (checking if it resolves locally
      or not)
      
      * add a delay
      
      * comment out test
      
      * [Actions] Add emitter-usages hydration
      
      This allows the front end to inform users of dashboards or cards that
      will be affected before deleting actions.
      
      Adds an `emitter-usages` hydration that shows emitters that reference
      a specific action or `is_write` card.
      
      The shape of `emitter-usages` is `[{:type "dashboard" :id 1 :name
      "Dashboard Name"} {:type "card" :id 2 :name "Card Name"}]`.
      
      * Add tests for new hydrations
      
      * add docstrings to 2 public emitter usage functions
      
      Co-authored-by: default avatarCam Saul <github@camsaul.com>
      Co-authored-by: default avatardpsutton <dan@dpsutton.com>
      Co-authored-by: default avatarBryan Maass <bryan.maass@gmail.com>
      Unverified
      b4033491
    • dpsutton's avatar
      Apply main args from bootstrap (#24730) · 5edfbdb6
      dpsutton authored
      Unverified
      5edfbdb6
    • Cam Saul's avatar
      Enable clj-kondo for driver namespaces (#24728) · 047a336b
      Cam Saul authored
      * Enable clj-kondo for driver namespaces
      
      * Fix CI command
      
      * Fix CI config (?)
      
      * Try hardcoding the driver directories in CI config
      
      * Fix some busted stuff
      
      * Enable the redundant fn wrapper linter
      
      * Appease the namespace linter
      Unverified
      047a336b
    • Aleksandr Lesnenko's avatar
    • Gustavo Saiani's avatar
    • Alexander Polyankin's avatar
  5. Aug 10, 2022
    • Nemanja Glumac's avatar
    • Case Nelson's avatar
      [Actions] Simplify emitter schema model (#24570) · 98bbb001
      Case Nelson authored
      * Move writeback migrations to 45
      
      * Empty commit to trigger GitHub Actions
      
      * [Actions] Simplify emitter schema model
      
      emitter_action was dropped since emitters just have a singular action
      and the join table was unecessary.
      
      emitter_action.action_id columns moved onto emitter table.
      
      Dropped CardEmitter and DashboardEmitter pre-insert, pre-update,
      pre-delete since they were used in tests only and normal operation
      would see the emitter inserted first.
      
      Since previous code may have 'orphaned' emitters without an action, we
      delete emitters without action to be safe.
      
      * Handle flakiness with geojson java.net.UnknownHostException errors (#24523)
      
      * Handle flakiness with geojson java.net.UnknownHostException errors
      
      In CI seems like we are getting errant errors:
      
      ```clojure
      geojson.clj:62
      It validates URLs and files appropriately
      http://0xc0000200
      expected: (valid? geojson)
        actual: #error {
       :cause "Invalid IP address literal: 0xc0000200"
       :via
       [{:type clojure.lang.ExceptionInfo
         :message "Invalid GeoJSON file location: must either start with http:// or https:// or be a relative path to a file on the classpath. URLs referring to hosts that supply internal hosting metadata are prohibited."
         :data {:status-code 400, :url "http://0xc0000200"}
         :at [metabase.api.geojson$valid_url_QMARK_ invokeStatic "geojson.clj" 62]}
        {:type java.net.UnknownHostException
         :message "0xc0000200"
         :at [java.net.InetAddress getAllByName "InetAddress.java" 1340]}
        {:type java.lang.IllegalArgumentException
         :message "Invalid IP address literal: 0xc0000200"
         :at [sun.net.util.IPAddressUtil validateNumericFormatV4 "IPAddressUtil.java" 150]}]
      ```
      
      Not clear if this change has a hope of fixing it: if it doesn't resolve
      once its possible it is cached somewhere in the network stack, or it
      won't resolve if you ask again.
      
      But gonna give it a shot.
      
      Set the property `"networkaddress.cache.negative.ttl"` to `"0"`
      
      > networkaddress.cache.negative.ttl (default: 10)
      >    Indicates the caching policy for un-successful name lookups from the name service. The value is specified as an integer to indicate the number of seconds to cache the failure for un-successful lookups.
      
      >    A value of 0 indicates "never cache". A value of -1 indicates "cache forever".
      
      From
      https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/net/InetAddress.html
      
      
      in the hopes that we can try multiple times. Restores the original value
      after the test completes so we don't inadvertently change behavior
      elsewhere.
      
      If we get an error of java.net.UnknownHostException we try again if we
      have attempts remaining. If we get a boolean it means the ip resolution
      worked so we can rely on the response (checking if it resolves locally
      or not)
      
      * add a delay
      
      * comment out test
      
      Co-authored-by: default avatarCam Saul <github@camsaul.com>
      Co-authored-by: default avatardpsutton <dan@dpsutton.com>
      Unverified
      98bbb001
    • dpsutton's avatar
      Sql autocomplete options (#24693) · 65b1b771
      dpsutton authored
      
      * `sql-editor-autocomplete-match-style` options for perf
      
      Large instances with 100ks of fields are choking on the select name from
      fields where name like "%search-term%`. Version in 43 was
      acceptable. This adds back the behavior in 43: prefix searching.
      
      Also adds ability to turn off if even the prefix search is burdensome.
      
      * Rename autocomplete-suggestion param `search` -> `substring`
      
      * support sql-editor-autocomplete-match-style on the FE
      
      * fix substring shows placeholder
      
      * Ensure using prefix style matching in e2e test
      
      * Make autocomplete style public
      
      * Rename defsetting to have "native-query" in name, not sql
      
      generally true. Consider mongo which has a native editor but no notion
      of SQL
      
      Co-authored-by: default avatarAleksandr Lesnenko <alxnddr@gmail.com>
      Unverified
      65b1b771
    • Nemanja Glumac's avatar
      [E2E] consolidate joins (#24707) · fe0c1b79
      Nemanja Glumac authored
      * Fix flake in repro for 12928
      
      * Refactor test for joins on tables
      
      - Merge repro for 12221 with the existing "base" test
      - Merge repro for 13468 with the existing "base" test
      
      * Remove deprecated `cy.server()` command
      
      * Remove tests that are not related to joins
      
      * Reproduce 11452 and 15570 using the existing test
      
      * Merge repros 13000 and 13649 together
      
      * Reproduce 13744 using the existing test
      
      * Merge two `joins` files together
      
      * Use the existing helper to open the products table
      Unverified
      fe0c1b79
    • Alexander Polyankin's avatar
    • dpsutton's avatar
      bump postgres to 42.4.1 (#24704) · e9a65ed5
      dpsutton authored
      addresses https://nvd.nist.gov/vuln/detail/CVE-2022-31197
      
      https://github.com/pgjdbc/pgjdbc/blob/master/CHANGELOG.md
      
      > fix: CVE-2022-31197 Fixes SQL generated in PgResultSet.refresh() to
      >    escape column identifiers so as to prevent SQL injection.
      >
      >    Previously, the column names for both key and data columns in the
      >    table were copied as-is into the generated SQL. This allowed a
      >    malicious table with column names that include statement terminator
      >    to be parsed and executed as multiple separate commands.
      Unverified
      e9a65ed5
    • Gustavo Saiani's avatar
      Add types to Pulse lib (#24692) · ff8d11c3
      Gustavo Saiani authored
      Unverified
      ff8d11c3
    • Nick Fitzpatrick's avatar
    • Jeff Bruemmer's avatar
      docs - embed restructure (#24702) · d84547eb
      Jeff Bruemmer authored
      Unverified
      d84547eb
    • Gustavo Saiani's avatar
    • Nemanja Glumac's avatar
      [E2E] Fix a flake in 17160 (#24691) · 85981c0c
      Nemanja Glumac authored
      Unverified
      85981c0c
    • Ngoc Khuat's avatar
      Referencing snippet in native query for mongoDB (#24656) · cea4835c
      Ngoc Khuat authored
      add support for reference snippet with mongo
      Unverified
      cea4835c
  6. Aug 09, 2022
Loading