Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add a Dockerfile #8

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open

Conversation

jwsloan
Copy link

@jwsloan jwsloan commented Oct 26, 2017

I wanted to give this a try, and thought I would provide the Dockerfile I used to try to get the server up and running.

It's not quite there... I get this far:

> Task :contract-creator:runServer
SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: Defaulting to no-operation (NOP) logger implementation
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.
Oct 26, 2017 4:35:36 PM org.jetbrains.ruby.runtime.signature.server.SignatureServer runServer
INFO: Starting server
<=<============-> 93% EXECUTING [4m 31s]
> :contract-creator:runServer
> IDLE

At that point, it never progresses. I've attempted to fix the logger class issue, but have not figured it out. Maybe someone can help?

@valich
Copy link
Collaborator

valich commented Oct 26, 2017

Oh, that may be actually useful, however some stuff might be fixed at project level, I think.
Actually, there is a big PR (#7) with review in progress which fixes some issues.

On idle server: that's normal; server listens for incoming data from arg-scanner runs to store them into a DB. However, in master, it still uses in-memory storage which is not really helpful (this is fixed in #7).
Still, in the current implementation the server flushes data into DB 5seconds after ruby process has stopped sending the data to it so it can be freely killed.

Later on this data might be queried from different tools (we currently develop only IJ/RubyMine plugin for that).

What is your use case?

@jwsloan
Copy link
Author

jwsloan commented Oct 26, 2017

Thanks for the quick reply, @valich.

I'm working on a gem that will generate sequence diagrams from ruby code, and am interested in seeing how this effort might help inform the other.

The very small beginning of that gem can be found here: https://github.com/nash-rb/sequence-diagram-rb

That gem was inspired by the ability to generate sequence diagrams from markdown, which IntelliJ Ultimate supports pretty nicely.

Would some portion of this Dockerfile be something you'd merge if I modified it?

@valich
Copy link
Collaborator

valich commented Oct 26, 2017

@jwsloan That's interesting, thanks! So, you may want to use such info to include parameters info to your diagrams, right?

Would some portion of this Dockerfile be something you'd merge if I modified it?

Sure, it's just I would like to discuss/understand how to use it. From my perspective it might be used as a "server" which accepts incoming data from arg-scanner runs — then we might like to open a port and conceive a way to retrieve the collected data.
Since the currently recommended way to persist the collected data is using mysql, we might also like to open a way to query the container about the data.

So, at this particular moment I have the following suggestions:

  • Let's remove logger fixes since they should be done at build.gradle level;
  • Let's add mysql server installation and setting up (like in .travis.yml)
  • Let's wait for Some fixes to run arg_scanner on diaspora specs. #7 to be merged because it fixes much stuff, enables mysql in runServer task and allows for port/user/etc. customization.

@jwsloan
Copy link
Author

jwsloan commented Oct 26, 2017

What I'm struggling with currently is to determine the sender of a message. It's fairly straightforward to know who received a given message, but the sender seems to be tricky.

I'm also not sure how we'll detect and accurately represent any iteration that occurs.

My thought on the Dockerfile was mainly a way for someone interested to quickly have the server up and running, or even just an environment they could spin up to easily start developing/contributing.

Those sound like great fixes. I'll watch for #7 to get complete, and then finish this PR. Would you like me to close it until then?

@valich
Copy link
Collaborator

valich commented Oct 27, 2017

Would you like me to close it until then?

That's up to you, but I would be glad to accept such contribution since configuring stuff can be cumbersome indeed.

@ViugiNick Do you have any thoughts on the sender calculation?

@ViugiNick
Copy link
Contributor

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants