Understanding Gemfile.lock: Is it okay to delete Gemfile.lock then run bundle install again?

23,585

Solution 1

You're probably not going to ruin your dev environment. However, you might end up with newer versions of gems than you had before. It depends on how you have defined them in Gemfile.

If you're using entries like:

gem "rails"

Then you'll get the latest rails gem, whatever that might be.

If you're using entries like:

gem "rails", "3.2.11"

Then you'll get 3.2.11 again.

Having said all of that, this is what branches are for. Make a branch in git, hg, or whatever you're using, blow away Gemfile.lock, run bundle install, and then check your test suite. If it's horrible, then you can abandon the branch while you figure out what went wrong.

Another tip: Any time I've ever wanted to do this, I found that it was useful to clear out all of my installed gems as well. If you're using rvm with gemsets this is as simple as running

rvm gemset empty [gemset_name]

Solution 2

It's ok to delete Gemfile.lock, just run

bundle install

to generate a new Gemfile.lock. Take note that if you didn't specify any version of a gem on your Gemfile, you will always get the latest

Solution 3

I know this has been answered already, but for everyone else that happens to come across this post on Google, you should know that command bundle init will regenerate the Gemfile.

Share:
23,585
Crashalot
Author by

Crashalot

Hello. My friends call me SegFault. Describe myself in 10 seconds? You know those feisty, whip-smart, sometimes funny, and occasionally charming developers who dominate StackOverflow and consider Swift/Ruby/jQuery their native tongue? Yah, I buy coffee for them.

Updated on October 27, 2020

Comments

  • Crashalot
    Crashalot over 3 years

    We would test this, but don't want to risk ruining our dev environment if this isn't supposed to happen.

    Is it okay to delete Gemfile.lock?

    We're on Rails 3.0.6.

  • Paul Richter
    Paul Richter over 10 years
    Hmm, for me I received an error message 'Gemfile already exists at /home/bla bla bla.... It did not regenerate the file. Perhaps that means the .lock file can be removed and regenerated with bundle init`, however if that is the case what would be the difference between that and simply bundle install?