This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2020-10-11
Channels
- # announcements (1)
- # babashka (132)
- # beginners (52)
- # calva (46)
- # clj-kondo (8)
- # cljdoc (17)
- # clojure (13)
- # clojure-australia (1)
- # clojure-dev (3)
- # clojure-europe (4)
- # clojurescript (4)
- # cloverage (1)
- # conjure (22)
- # datomic (9)
- # emacs (2)
- # fulcro (16)
- # leiningen (5)
- # malli (26)
- # off-topic (16)
- # pathom (3)
- # portal (5)
- # reagent (10)
- # reitit (5)
- # rewrite-clj (1)
- # ring (1)
- # shadow-cljs (14)
- # spacemacs (6)
- # tools-deps (10)
- # vim (11)
- # vscode (1)
- # xtdb (10)
ok I got routing halfway setup. right now it looks like it'll load different components, but nothing is being loaded into the component. Before setting up this router I had everything set up in the initial state, could that be why?
niche issue: set-ident-route-params
in legacy-ui-routers
doesn't work recursively, so if you have a nested ident like [:table/id {:inner :param/id}]
that param doesn't get replaced. clojure.walk/postwalk
instead of mapv
seems to do the trick. PR wanted?
I am setting up testing for our project, and have run into an issue: my pathom mutation uses form/save-form*
and just using mock-resolver-env
is not enough to cover that; I get runtime errors because the form middleware is missing. Has someone done mocked testing with that before and knows a good way to do it?
@njustice the template is set up quite nicely already, forwarding all JVM logging styles to timbre, and configuring timbre through the edn config…what else are you talking about? You could add a sentry appender to timber for error level messages…
@zilti I’ve done the following two styles: 1. write a macro for doing the boilerplate setup in a test (I think I called mine full-stack-round-trip) that sets up everything except the networking and runs EQL through it. 2. Consider the plumbing to be a separate testing story and just test the core logic of the thing, so that the pathom resolver is really just a pass-through to that function. In either case you’re going to have to do the necessary env setup for save-form* if you want save-form* to work. No idea which mock-resolver-env
you’re talking about, but the built-in middleware is side-effect free, so you can just compose that stuff into an env.
I'm talking about the mock-resolver-env
from fulcro-rad-datomic. I tried to just assoc
the save- and delete-middlewares into the generated, but that gave me NullPointerExceptions.
I am considering to just run the main mount/start
and use the actual thing for testing, with a bunch of centralised mock data in an in-memory db
@kevin842 if you understand the problem, have a repro case, and want to, sure. I really don’t want to put my head into those older routers at this point.
I may need help ensuring I'm understanding this right. I'm trying to get a working instance of example 38 in my code; a dynamic router. Can a router replace sub components, or can they only replace the data tree of some component? From 38 it looks be the latter of the two, but I was wanting to set up a router that loaded a different component when navigated to via an onclick, for instance.
A router can have different targets, ie different target component, eg Person Overview and Person Details
do the targets have to assume that the structure of dating being passed in is identical between the two components?
what do you mean by "dating"? Passed in to what? Two components used as targets on the same router are completely independent and can have completely different queries and idents.