This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2017-03-01
Channels
- # bangalore-clj (1)
- # beginners (16)
- # bigdata (1)
- # boot (16)
- # cljs-dev (79)
- # cljsjs (37)
- # cljsrn (62)
- # clojars (1)
- # clojure (260)
- # clojure-austin (3)
- # clojure-dev (3)
- # clojure-dusseldorf (3)
- # clojure-italy (1)
- # clojure-russia (32)
- # clojure-serbia (2)
- # clojure-spec (8)
- # clojure-uk (146)
- # clojure-ukraine (16)
- # clojurescript (66)
- # cursive (27)
- # datomic (57)
- # dirac (124)
- # emacs (10)
- # hoplon (12)
- # juxt (6)
- # keechma (6)
- # lein-figwheel (18)
- # leiningen (6)
- # lumo (51)
- # off-topic (1)
- # om (66)
- # onyx (41)
- # perun (1)
- # play-clj (1)
- # protorepl (9)
- # re-frame (20)
- # reagent (11)
- # ring (4)
- # ring-swagger (10)
- # rum (22)
- # specter (8)
- # sql (2)
- # test-check (5)
- # untangled (27)
- # yada (29)
saw someone running into this on the latest osx (sierra?) when trying to install packages from melpa. The issue seemed to be that osx put that cert inside of a cert store that it was unwilling to share with emacs in the normal way
I don't believe it is really emacs specific though so if you wanted to look into that
Hey all, anyone have any suggestions on an existing web-based CMS (with end user content editing features) that's a good fit for clj / cljs website development? I'm more interested in the fit with Clojure, ring, friend etc, and the UX for content administrators than that the CMS itself be written in Clojure.
@zea: https://www.youtube.com/channel/UC6yONKYeoE2P3bsahDtsimg definitely worth $3.99 / month
====== in core.match, is there a way to say : if a variable is arleady bound, BIND IT AS NEW VAR, instead of expecting it to match up with old value? for example
(let [x 3
point [:vec2 23 34]]
(match [point]
[[:vec2 x y]] --> fails since instead of binding x=23, it expects 3 = 23
now, I could prefix my vars with ?x ?y or x y ... but then I'd also ahve to use ?x ?y or x y on the rhs
is there some way where:
I use ?x ?y on lhs, and x y on rhs
or
I use x y on lhs and x y on rhs
?http://www.parens-of-the-dead.com/ <-- also good if you want to see a pro at work
@zea: wait, so youtube blocks your country based on IP, but doesn't block your country based on credit card ?
Hello, developers! Can someone guide me on how to get started with Contribution to Clojure; in terms of the mode of communication preferred (which channel on Slack? ) and tools ?
@zea (def name 1)
- defines a var, defn
is a kind of shorthand for (def name (fn …))
iow, it defines a function
@zea In the future I think questions of that nature are more suitable for #beginners
def
binds a name to a value, yes
I recommend clojure koans to get initial skills
got it @residentsummer 👍
Morning! core.match
Q: I need to store some patterns outside of a match function and I have troubles with apply
(because core.match is a macro? and because I'm on cljs?) What is the normal way of doing this?
@jellea I don't think core.match has dynamic matching, so the only way to use core.match with runtime-resolved patterns would be to use eval
...
@val_waeselynck hmmm that might be an option!
@jellea do those patterns just stored in the different place?
or they ain’t known at compile-time?
in the first case it’s possible to write a macro that will produce required match
form with your patterns resolved at compile-time
permacode, a library for content-addressable clojure code, looks interesting: https://brosenan.github.io/permacode/core.html
could this be used to build up a spec registry of community-tested functions?
that way generative tests for specced functions would only have to be run once globally
It throws the following exception IllegalArgumentException No matching method found: setCapability for class org.openqa.selenium.remote.DesiredCapabilities clojure.lang.Reflector.invokeMatchingMethod (Reflector.java:80)
are you sure both arguments are Strings?
try wrapping them in (str)
I suspect the first one may still be a keyword
Hi guys, I have a question about leiningen. Is it okay to ask about it here, or is there a lein channel?
here's fine I think
there's #leiningen too
@pesterhazy thanks, I'm going to ask there first
@kepinpin : boot is amazing; I always found lein unapproachable where I could configure existing plugins but never write my own; boot on the other hand, is pretty straight forward in comparison
by the way, the lein channel seems to be pretty quiet, so I'm asking here too: I tried this :jvm-opts ["-Xbootclasspath/a:/usr/lib64/libreoffice/program/classes"] but when I connect to the repl and print the classpath, the path is not there
looks like there's a typo there?
reformatting, my question is: I input the option :jvm-opts ["-Xbootclasspath/a:/usr/lib64/libreoffice/program/classes"] to my project.clj. But when I connect to the repl and print the classpath, the path is not there
hmm maybe not, hadn't heard of -Xbootclasspath
have you tried export JVM_OPTS=...
?
or is it JAVA_OPTS?
@pesterhazy not yet, I'm going to try that thanks
@rauh (.getInputArguments (java.lang.management.ManagementFactory/getRuntimeMXBean)) ["-Dfile.encoding=UTF-8" "-Xbootclasspath/a:/usr/lib64/libreoffice/program/classes" "-Dclojure.compile.path=/home/target/base+system+user+dev/classes" "-Dcljlop.version=0.1.0-SNAPSHOT" "-Dclojure.debug=false"] there it is!
@bigkahuna in script start.sh: export JAVA_OPTS=-Xbootclasspath/a:/usr/lib64/libreoffice/program/classes/* lein run -- still no luck 😞
anyway, what I wanted to do is to include another dir into my clojure app's classpath. What's the best way to do this anyway?
Our open source learning group is hosting the free online webinar Essential Klipse this Saturday at 7 pm UTC. Everyone is welcome! http://discuss.thevalueoflearning.org/t/webinar-discussion-2-essential-klipse/39?u=jay
I added into the project.clj :src ["/usr/lib64/libreoffice/program/classes/"] but still can't access the classes in the jars
Can I write a commandline programm with clojure? I found the cli.tools but didn't find a info, how to run such a programm on the command line
@danielgrosse sure it's easy
the most basic thing you can do it to just call the clojure jar directly: https://clojure.org/guides/getting_started
another option is to use boot (which has great support for command line argument parsing), or lein run: https://github.com/clojure-cookbook/clojure-cookbook/blob/master/03_general-computing/3-06_running-programs-from-the-command-line.asciidoc
@danielgrosse for a shorter script startup time, you could use Clojurescript with planck (https://github.com/mfikes/planck) or lumo (https://github.com/anmonteiro/lumo). But it's Clojurescript so you can't always use the same dependencies (tools.cli should work). Here is a guide for planck scripting: http://planck-repl.org/scripts.html Lumo is very similar to planck but has node.js integration and is more cross-platform
and planck has its own channel #planck, where @mfikes normally hangs around ready to help
Thank you both. I wrote the whole in Clojure, so change to CLJS isn't neccessary.
One question out of curiosity. How could I reduce the size of the final jar file?
@cgrand saw your gist on an edn-based a repl. I think that's an excellent idea
Okay I removed some unused dependencies and it shrunk from 90 to 2MB :thumbsup:
I was thinking about this topic before. My sense is that the fact that nREPL is (too?) complex has held back progress. In combination with socket server a solution like the one you propose could be very helpful
to build simple tooling that can be consumed from emacs etc.
Not just for clojure but for clojurescript also
@pesterhazy I agree but I have to run, let’s talk later
ping me whenever
@pesterhazy I agree...there's a lot that could be done with socketrepl, even "EDN Repls" are simply a socket repl + some setup inside the connected JVM instance
I'd love to see a "nrepl" that doesn't polute the remote end with extra libraries. Just the JVM + Clojure + a TCP socket, everything else can be setup from a remote process via sending code through the socket.
I've been using socket REPL with inf-clojure-mode lately. Works quite well: Emacs comint mode can connect directly to a socket, no "client" process needed.
Right and if your editor did need to get more information about the process (a docstring for example) it could easily create another socket repl connection, a "scratch" namespace and run whatever code it needs to get at that data.
hi. I remember there was a library for clojure that allows to build reagent-like reactive data chains of atoms with just clojure. I can't find it in google for some reason. anyone remembers its name?
In fact more specifacally Javelin? https://github.com/hoplon/javelin
Released Specter 1.0 and wrote a post about why I consider it Clojure's missing piece http://nathanmarz.com/blog/clojures-missing-piece.html
am I understanding it correctly that if I want to use derive/isa? on a custom hierarchy, I have to reassign the results of derive myself?
I'm used to using (map-indexed)
to keep an iteration index when I'm looping over stuff with (for)
:
(let [stuff [:a :b :c]]
(for [[idx thing] (map-indexed vector stuff)] {thing idx}))
=> ({:a 0} {:b 1} {:c 2})
Does anyone have a good trick for doing this in a nested loop?
(let [stuff {:a #{:x :y} :b #{:y :z}}]
(for [[outer-idx [k v]] (map-indexed vector stuff)]
(for [[inner-idx leaf] (map-indexed vector v)]
[outer-idx inner-idx k leaf])))
=> (([0 0 :a :y] [0 1 :a :x]) ([1 0 :b :y] [1 1 :b :z]))
...I can do this with loop/recur or a reduce with an accumulator, just think I'm missing a more obvious way to do it
What I'd like to wind up with is more like ([0 :a :y] [1 :a :x] [2 :b :y] [3 :b :z])
(I can deal with the list-nesting stuff, I'm more interested in the indices)
FWIW, I solved my problem by having the nested loop produce [k leaf]
paris and then (map-indexed)
ing over that separately:
(let [stuff {:a #{:x :y} :b #{:y :z}}
pairs (apply concat
(for [[k v] stuff]
(for [leaf v]
[k leaf])))]
(for [[idx [k leaf]] (map-indexed vector pairs)]
[idx k leaf]))
;;=> ([0 :a :y] [1 :a :x] [2 :b :y] [3 :b :z])
Not super-enthused about the extra iteration, but the code itself is readable
@nathanmarz congratulations for specter's 1.0 release
@timgluz you could try
(map-indexed #(vec (cons %1 %2)) pairs)
instead of the last for loop. dunno if thats better thoughOh, hmm, yeah, I'd forgotten about the multiple-seq version of for
Well, that does make it a god deal tidier:
(let [stuff {:a #{:x :y} :b #{:y :z}}
pairs (for [[k v] stuff
leaf v]
[k leaf])]
(for [[idx [k leaf]] (map-indexed vector pairs)]
[idx k leaf]))
;;=> ([0 :a :y] [1 :a :x] [2 :b :y] [3 :b :z])
(transduce
(comp
(fn [f]
(fn
([accum] accum)
([accum [k v]]
(reduce
((map #(list k %)) f)
accum
v))))
(map-indexed (fn [i thing] (vec (cons i thing)))))
conj
[]
{:a #{:x :y}
:b #{:y :z}})
Or with @spei's suggestion
(let [stuff {:a #{:x :y} :b #{:y :z}}]
(->> (for [[k v] stuff
leaf v]
[k leaf])
(map-indexed #(vec (cons %1 %2)))))
;;=> ([0 :a :y] [1 :a :x] [2 :b :y] [3 :b :z])
(transduce
(comp
(map (fn [[k v]] (into [] (map #(list k %)) v)))
cat
(map-indexed (fn [i thing] (vec (cons i thing)))))
conj
[]
{:a #{:x :y}
:b #{:y :z}})
(transduce
(comp
(map (fn [[k v]] (eduction (map #(list k %)) v)))
cat
(map-indexed (fn [i thing] (vec (cons i thing)))))
conj
[]
{:a #{:x :y}
:b #{:y :z}})
Hi
I am thinking of using mount
as an indirection layer to an http client. Something like
(defstate get :start http/get)
With the purpose of being able to “mock" it while avoid using with-redefs
- which I don’t like too much.
I do not know if this is a good idea of it is me missing something fundamental. Any thoughts about it?
Thanks in advanceuhm could you elaborate on that, please?
There's a #mount channel you could ask about that in. Personally I like mount, but I'm not sure if makes sense for things that are essentially stateless like http/get
Thanks @timgilbert . The point is about to use start-with-states
to replace the implementations
I like component, which is an opinion, "component is good"; mount being terrible is a fact
My english is far from being perfect. Probably I am not clear about the meaning of fact and opinion
@cristobal.garcia you could use just start-with
to provide a value vs. a state:
(mount/start-with {#'app/foo (http/get ...)})
more about it: https://www.dotkam.com/2016/01/17/swapping-alternate-implementations-with-mount/@tolitius Thanks. That was exactly the plan. But not for alternate viable implementations, just for mocking
@cristobal.garcia right start-with
is usually used for stubbing / mocking in tests
@hiredman. I am not exactly sure I agree with you. mount turns some state into someting I don’t care too much if if works as states
clojure defs are global singletons, atoms are mutable, mount stores state in global atoms, mount turns your system in to a mutable singleton
That is brilliant @tolitius . My mind is at peace now knowing the idea I had in mind make sense. I will have a look at start-with
@hiredman The server the code runs on is a global singleton as well and I am not going to be able to live without it.
@cristobal.garcia very welcome
have you noticed the new design of github? the new blue is burning my eyes, is it only me?
istvan: the blues are bluer, greens are greener, and the purples are purplyier
well, you will have to live with it. I worked on a clojure project that had a runtime system similar to mount that kept everything in global atoms for five years, and it is not the way to structure software
@hiredman Thanks for your opinions, they are very much appreciated. I will consider them carefully.
@tolitius Thanks again! I am taking my hat off 🙇
@cristobal.garcia from my side of things I don't care if people use one library or another. It's just global mutable state is bad...really, really bad. That's what this whole Functional Programming thing is about. And yet for some reason it's now considered a good idea to go and structure our entire apps around global mutable state. There's no reason for it at all. Functions have parameters, pass in everything the function needs via a parameter. That keeps your code thread-safe (one function doesn't muck with the global state of another function), clean (I always know what state a function needs to run), and extensible (I can pass new impls to a old function). This is basic FP stuff...I'm not sure why it's suddenly hip to have global mutable state.
I find the whole thing rather confusing. People can disagree, but if you want global state...why are you using Clojure?
@tbaldridge I am a little bit surprised. Do I need to pass every function another function uses as a parameter?
you don't (or shouldn't) mutate global functions while your app is running
at least not in production. If you're mutating vars at runtime that's a big red flag. You should be able to "freeze" every var in your app at compile time and things should "just work"
@tbaldridge I believe in previous discussions, mount users have said they do this. (Passing round db as an argument)
@tbaldridge i guess the doom of javascript devs reached clojure, time to evacuate! 🙂
I am not planning to. But I do need to unit-test my code. Is there any way I can replace a dependency in a test without adding it as a parameter to the function-under-test?
@dominicm that may be the case, but the framework doesn't work that way, go read the source, everytime you start the system it goes and throws a bunch of state in a global atom. Every "defstate" just does a get-in in that atom
@tbaldridge ah, I thought it as the api you disliked, vs the impl
because component is using values and is not global, it is entirely possible to do things like spin up multiple copies of a system in the same jvm (baring other constraints) and doing things like running tests in parallel, or testing communication between multiple systems
@cristobal.garcia yes! thanks for asking! Two good ways is to a) add the parameter...there's nothing wrong with that. b) test the output of your function. Don't have (get-user ..) make an HTTP call and try to test that, have (make-get-user-request ...) and test the output of that function
@hiredman agreed, I've tested entire distributed systems where we replaced Tibco with Hornet, Datomic with a atom, etc.
@dominicm you really cant....
@dominicm at least not with an explosion of namespaces for each new DB connection your app needs, mount doesn't compose the way other DI systems do.
@tbaldridge a) agreed for some cases. Wide signatures go against code being understandable and this is paramount. b) I am not sure I am getting you
It's perhaps worth noting that mount doesn't claim to be a DI framework afaik. DI is for users to use.
whatever mount claims to be, it is a pile of uncoordinated (multiple atoms) global state inside
these 30 lines are enough https://gist.github.com/hiredman/075b45eaeb01e4b526ce6f8854685487 you can build great systems with great properties and the ability to rewrite and swap out parts at will for testing or whatever else you need to do
@cristobal.garcia that's the power of stuff like Component, you add one argument, and all your deps are in that
if you want all that and slightly better error messages if things go wrong, use component
@cristobal.garcia so your functions look like this:
(defn get-user [{:keys [db] :as di-state} user-id]
...)
https://www.dotkam.com/2016/01/31/yurt-mounts-local-real-estate/ yurt is the way to do it. I had thought that it let you do binding style stuff to mock things, but apparently not.
dominicm: i'll give yurt credit for not picking a generic name like "component" or "system". do we call our dog "dog"?
@cristobal.garcia in this case though, what are you trying to test?
@tbaldridge functions that get some data from a REST-like interface
@tbaldridge I've always found that vars like di-state get abused and quickly become incomprehensible as to their actual contained state.
I would rather prefer not to use a mock/stub http server
to be clear, component doesn't pass around a single di-state, what you get for di-state is only the stuff you have told component you depend on
@cristobal.garcia so in that case . There isn't much of a reason to test the HTTP lib, right? Chances are someone else wrote that, what you really want to be testing is that given certain parameters, the correct HTTP request is generated
@tbaldridge indeed you are right
So make a function that generates HTTP requests (HTTP requests are maps after all), and test the output of that function.
Combine that with something like Component for integration tests, and you've got a nice system setup.
@tbaldridge please correct me if I am wrong but HTTP requests will be whatever the library I need to use asks me for. Maps or maybe something else.
If I need to write a layer to transform maps into clj-http calls, how do I test that layer?
That you'd hit in integration tests. At least that's how I write my code. Business logic can be exercised with unit tests. Side effecting code should be parameterized by components I can swap out with other components.
https://github.com/dakrone/clj-http/blob/master/src/clj_http/client.clj#L1152-L1156 clj-http calls are maps to some extent
@tbaldridge agreed about unit-testing business logic. I need to think about your approach for the side-affecting code. Thanks for your time
@hiredman Yes. Thank you again
np, stick around, I'm sure we'll all argue this again next week 🙂
I'd like to find an excuse to use Integrant soon.
@tbaldridge may I ask you a final question?
sure!
thanks! Let’s imagine I have decomposed my business logic and everything lives in pure functions. Now I need a final layer of the cake. A very simple function which takes a map and makes a POST to a web server. Everything else is pure. How do suggest I do test this one?
the 30 line gist above can just be pasted in to your app, and you get all the benefits of component without having the worry about the name or include any library
@cristobal.garcia I have tested things like by starting up a jetty server(in process) and making requests to it
Start a web server? I would have expected something lighter
Or I may want to test I do the right call and correctly process the returned results
there are libraries that do things like record http requests and response, and then you can play those back
I am not a huge fan of that, but it exists and people do it, presumably because they are worried about the overhead of firing up a webserver
@dominic you are right but I am interested on the impure code
@hiredman well yes but I could approach the problem having more unit tests and less integration tests
@cristobal.garcia At work we have system / integration tests that take like 2 - 3 hours to setup before the tests start at all. So, from my point of view, starting a web server for integration tests is nothing I would be afraid of 😄
I might prefer to re-use a jetty instance of a few tests, instead of a new one per test, and there are all kinds of ways of doing that depending on your testing library
@sveri agreed but it is not about this. I have needed to try an snmp client. Should I start an snmp server too? Well good for integration tests but I want to have more (and fast) unit tests
@cristobal.garcia we use component
to manage deps, and we have http-client component (initialised with endpoint and other stuff). to test interaction with other services we use smth like https://gist.github.com/little-arhat/c4da3415b88a0ddf8214f09dc44fff9a — mocked client essentially
if what you want to test is the io between a client and a server, then yeah, you need a client and a server
Hey fam, java-ish question. Does future.get() not always block? What if I have a Thread.sleep() within the .call() method? I'm having weird concurrency issues with a program that uses 4 Future.get()s in a row (for timeout purposes), they don't seem to always execute sequentially.
Future is an interface, and it will depend on the implementation, but clojure futures start as soon as they are created
@larhat thanks. That is interesting
@cristobal.garcia so, for the test, we can change dependency of our final system (real client to mocked one) and test system’s lifecycle, without hitting real world
@hiredman Yes, on an end-to-end test I want. Do I want to test everything on end-to-end tests? Absolutely not
@larhat Same approach that java https://developers.google.com/api-client-library/java/google-http-java-client/unit-testing
are you just trying to check that clj-http is called with the arguments you pass it?
@hiredman I want to test I call clj-http with the right arguments
That is why I understand a unit test is
I don't think I would bother, there are things you could do (using with-redefs, which is usually a bad idea, but can't always be avoided) , but if you have your map -> map function, and clj-http is only ever called on that map
@larhat probably you aren’t testing the replaceable implementations since they have the same problem
for example, if your whole system took as a parameter a function like (fn [m] ...)
and used that passed in function to make http requests, in your test to ensure that function is called you could swap it out with any function, something that recorded the arguments passed
and everywhere else you migh just pass the plain clj-http.client/request*
function to your system
I see. I think I now have understood. I am a little disappointed, though
I do like to use test-first approaches. Finding places where this is more difficult to approach than I expected (traditional stubs) is something I still need to process
I do not need magic. A simple mocking solution would work for me. There are places where purity is not possible and, for then, I do not see why I need to rely on doing everything with costly integration tests
but other than this, I do love clojure
@cristobal.garcia This is how I setup my test system: https://github.com/sveri/closp/blob/master/resources/leiningen/new/closp/integtest/clj/setup.clj#L33
In the system you can write your outside reaching components the way you want. Mix and match whatever you need. I dont really understand the problem, tbh.
bradford: get is blocking, but the order of the gets doesn't effect the order of execution, it is going to depend on the executor. if the execute has more than one thread you could get some interesting race conditions of any logging
@sveri, Yes I am probably needing some months as well 🙂
@cristobal.garcia Yea, coming from a state dominated java world, in my case, I had to rewire my brain several times, but, it was totally worth it.
Yeah. (this is a webcrawler with Selenium, so I have lots of timeouts because Web browsers are freezy and crashy. I've got an Executors.fixedThreadPool of size 40, and then Futures that DownloadURL, TakeScreenshot, ParseResults, and UploadResultsToS3, each with a timeout. What I'm seeing is that sometimes, it'll try to ParseResults when TakeScreenshot isn't done, even if TakeScreenshot times out. It's...odd. I'll turn it down to 1 thread and see if life gets more sane.
if you through all those futures on the workqueue at the same time, some of thsoe threads will be pinned for a long time doing long running tasks
to document APIs what do Clojure people prefer? Swagger/RAML/other?
maybe spec will be used for that as well?
or could be used