Giter VIP home page Giter VIP logo

Comments (6)

jesseshieh avatar jesseshieh commented on June 12, 2024 1

Thanks @hez. I like that suggestion.

Right now, according to this we basically check for ${cache_path}/elixir-${elixir_version}.zip

We could change this to ${cache_path}/elixir-${elixir_version}-otp-${erlang_version}.zip

The file we download usually looks something like this anyway:

-----> Fetching Elixir v1.10.3 for OTP 22 from https://repo.hex.pm/builds/elixir/v1.10.3-otp-22.zip

The code that fetches it even uses the otp_version and then throws it away when writing the elixir_download_file. I wonder if perhaps the otp_version is all we need rather than the entire erlang_version.

from heroku-buildpack-elixir.

jesseshieh avatar jesseshieh commented on June 12, 2024

Thanks for the bug report @jbrowning. I guess we could try and implement something to check the compatibility matrix described here
https://hexdocs.pm/elixir/compatibility-and-deprecations.html#compatibility-between-elixir-and-erlang-otp

Perhaps in this function which checks the erlang version.
https://github.com/HashNuke/heroku-buildpack-elixir/blob/master/lib/canonical_version.sh#L20

Any help implementing this would be greatly appreciated!

from heroku-buildpack-elixir.

hez avatar hez commented on June 12, 2024

We had this happen and had to turn off caching completely. We could turn it on then turn it off on lang update but that seems like a lot of work.

from heroku-buildpack-elixir.

hez avatar hez commented on June 12, 2024

@jesseshieh I would suggest tagging the cache with the otp + elixir ver and invalidating it if it changes at all. That would be easiest and cover all bases.

from heroku-buildpack-elixir.

jbrowning avatar jbrowning commented on June 12, 2024

@jesseshieh Yeah elixir_version + otp_version like the original filename is all you need to retain in order to fix this. Minor Erlang version changes will still download the same OTP version.

from heroku-buildpack-elixir.

jesseshieh avatar jesseshieh commented on June 12, 2024

I just submitted a pull request with a potential fix. I tested it briefly and it seems to work. If you guys want to try it out, change your buildpack to https://github.com/jesseshieh/heroku-buildpack-elixir#js/elixir-otp-version-cache and see if everything works okay.

from heroku-buildpack-elixir.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.