-
Notifications
You must be signed in to change notification settings - Fork 21
Add mix.lock file #27
base: master
Are you sure you want to change the base?
Conversation
Add a mix.lock file with the latest version of depenedencies. Tests run fine with these for me and they all match `mix.exs`. Will help bugs arising from contributors using different versions of dependencies. Similar to what happened in: ScenicFramework#26
Do we or should we have a test for |
@boydm I just found an amazing resource for us: TLDR; We should:
|
@Eiji7 Interesting. And reminds me that the reason I didn't include the lock files was to allow the packages to "float" version-wise in the host project. Use its dependencies as it were. I'll re-read it again tomorrow. |
I agree that the approach of allowing the dependencies to "float" in CI by removing the |
@boydm I believe that this solution + @axelson proposition would be really helpful. However something is still in my mind … Should we prevent updating I'm not sure if I would have time soon and if so I would like to take a look at UI scaling issue. Maybe I could debug it somehow and give you any ideas on it … I did not yet analyzed whole code, so it would be helpful if you could give me a hint where scaling on window resize is handled. |
@Eiji7 Right. Still doesn't quite sit right. In fact I think the core issue we were facing in the first place was that it was the wrong version elixir_make. Or rather, that elixir_make made a breaking change that affected the driver. Including the mix.lock file might be a "red herring" that could cause more trouble than it solves. |
I am definitely still in favor of having a mix.lock committed in the repository and I am of the opinion that it will be more helpful than hurtful. I don't think it needs to be locked down to only dependabot because sometimes as a contributor you will want to update the version requirement in mix.exs and mix.lock simultaneously. I think the CI approach I am in favor of is to always run CI against the upper-most versions specified in mix.exs which means that the CI will be operating effectively as if the mix.lock file was not committed to the repository. In addition to running CI on every pull request/branch push I think it would be advantageous to set the CI to run every day (using the cron feature: https://docs.travis-ci.com/user/cron-jobs/), that way if there's a new release of a downstream library that breaks scenic_driver_glfw, we can be notified of it right away. Dependabot could then be added on top of this setup as a developer nicety to not need to manually keep mix.lock up to date. I'm working on getting a branch with a working travis configuration up as a base, but I'm running into a little trouble. Possibly because the CI is run on a headless server, I haven't dug into it enough yet (you can find my work in progress at https://github.com/axelson/scenic_driver_glfw/tree/add-travis-config and an example failing build is at https://travis-ci.org/axelson/scenic_driver_glfw/jobs/564751545). I am also able to reproduce the build failure on my headless ubuntu server (running 19.04) which should help in figuring out the fix. |
Add a mix.lock file with the latest version of depenedencies. Tests run fine with these for me and they all match
mix.exs
.Will help bugs arising from contributors using different versions of dependencies. Similar to what happened in: #26
Alternatively we may want to add this is #26 directly in which case this can just be closed (also I figured that we'd bump the elixir_make version in #26 since it is semi-related)