Fork me on GitHub
#sql
<
2021-06-25
>
Jakub Holý (HolyJak)12:06:24

Hi @seancorfield! Is it possible that the effect of extend-protocol next.jdbc.result-set/ReadableColumn somehow "randomly" depends on the order of loading things? I sometimes observe that it seems not to have taken effect and I suspect it it because this is inside a library my app depends on while the app also depends on next.jdbc directly. Could it happend based on through which of the two "paths" next.jdbc is loaded first? The library has the extend-protocol call at the very top, extending ReadableColumn to java.sql.Timestamp to convert it into java.time.Instant . Further down in the same namespace I have a function that reads a timestamp from the DB and tries to use it as an Instant and fails in some instances of the REPL because it gets java.sql.Timestamp instead. This never happens in prod, only when running the app locally, from a REPL. Any tips? 🙏

emccue16:06:26

@holyjak If the protocol itself gets reloaded and your extend calls don't, that could be the cause

❤️ 2
Jakub Holý (HolyJak)16:06:28

Hm, that could be related, thank you! I think we did (clojure.tools.namespace.repl/refresh) Though I would expect it to reload both things and in the correct order ... /cc @U8T02L5C7

seancorfield16:06:43

Solution: don't use tnr/refresh 🙂

seancorfield16:06:57

(this is exactly why I avoid these reload/refresh workflows!)

👍 2
emccue16:06:46

it would essentially be the same as

emccue16:06:20

(deftype A [])

(defprotocol B 
  (f [_]))

(extend-protocol B
  A
  (f [_] "abc"))

(defprotocol B 
  (f [_]))

emccue16:06:44

so the var f would be rebound to the new protocol function

emccue16:06:01

and would throw if called on A