Shree
Shree

Reputation: 583

Why does Heroku fail to detect Node.js buildpack?

I git cloned a Node.js application (the version specified in the package.json being 4.1.2 and that of my local machine being 6.2.2) and tried to git push on Heroku. But it failed to build and gave this error:

Failed to detect set buildpack https://codon-buildpacks.s3.amazonaws.com/buildpacks/heroku/nodejs.tgz

Now I set the buildpack to heroku/nodejs and I get this message:

Buildpack set. Next release on lit-badlands-92088 will use heroku/nodejs.
Run git push heroku master to create a new release using this buildpack.

Now when I run git push heroku master, I am again told:

remote: -----> Failed to detect set buildpack
        https://codon-buildpacks.s3.amazonaws.com/buildpacks/heroku/nodejs.tgz  

remote: More info: 
https://devcenter.heroku.com/articles/buildpacks#detection-failure  

remote:  
remote:  !     Push failed  
remote: Verifying deploy...  
remote:  
remote: !       Push rejected to lit-badlands-92088.

What could be the possible reasons for the Node.js buildpack not being detected even if I set it?

Upvotes: 30

Views: 39467

Answers (8)

Scott
Scott

Reputation: 4331

It’s because Heroku thinks you are deploying a Node app. But what you are deploying is the public directory of a Node app, not Node code.

Heroku uses buildpacks to select how the app is handled. You want to clear that Node association:

heroku buildpacks:clear # clear all buildpacks set on the app

Which means that “Next release will detect buildpack normally.”, that should solve it for you.

ref: https://devcenter.heroku.com/articles/buildpacks

Upvotes: 10

Atif Nasim Khan
Atif Nasim Khan

Reputation: 1

I add Pakage.json file, and then

Remove old git. folder: rm -rf .git

Create new git: git init

Add all project files: git add .

Commit: git commit -m “commit name”

Creat new heroku application: heroku create

Push code to master: git push heroku master

App successfully deployed on heroku.

Upvotes: 0

GeorgeS
GeorgeS

Reputation: 107

I run into the same issue and tried everything, eventually realized no file would commit because they were already committed and pushed to the github repository. So you need to do the following:

  • Remove old git. folder:

rm -rf .git

  • Create new git:

git init

  • Add all project files:

git add .

  • Commit:

git commit -m “commit name”

  • Creat new heroku application:

heroku create

  • Push code to master:

git push heroku master

This worked for me.

Upvotes: 1

Akash Kandpal
Akash Kandpal

Reputation: 3366

Most apps have at least one of these signatures present, so if you see this error, it usually means an important file isn't checked into your git repository:

  • Java: pom.xml

  • Ruby: Gemfile

  • Node.js: package.json

  • Python: requirements.txt / setup.py / Pipfile

  • PHP: composer.json / index.php

You should:

git add {file}
git commit -am 'added {file} 
git push heroku master

Upvotes: 1

Del_sama
Del_sama

Reputation: 61

If you are working on a branch, you need to set master to track your branch

git branch -f --track master origin/branch_name

Check for package.json in master

git show master:package.json

If it's available, trying pushing again.

git push heroku master

`

Upvotes: 4

hunterloftis
hunterloftis

Reputation: 13799

This means that a package.json file isn't checked into the root of your git project, so Heroku is detecting that it isn't a Node.js app. You can see this locally:

git show master:package.json

To fix it, you'll want to be sure there is a package.json in the root of your project (where there is also a .git directory), and add it to git:

git add package.json
git commit -m 'track package.json'

The phrasing ('failed to detect set buildpack') could be improved. It should probably say 'failed to detect Node.js app'. When the buildpack's "detect" script is run (https://github.com/heroku/heroku-buildpack-nodejs/blob/master/bin/detect), it looks for a package.json file to verify that there's a node app available to build.

Upvotes: 39

Aaron Chamberlain
Aaron Chamberlain

Reputation: 671

Some tiny clarifications on other answers: The error "Failed to detect set buildpack https://codon-buildpacks.s3.amazonaws.com/buildpacks/heroku/nodejs.tgz" or anything similar, means to say the GIT COMMIT you are trying to push to heroku was not DETECTED as a node.js app. (Note the capitals for subtleties).

I recently made a stupid mistake that made me aware of this: Running "ls -a" showed that my package.json and .git files were in the same root directory, as required by heroku. EXCEPT that the package.json file WAS NOT included in my latest git commit. Running "git status" alerted me that package.json was an untracked file. So I added it, and ta-da, pushing to heroku worked.

If you get an error related to buildpack, check that your GIT COMMIT has a package.json file in the root directory. If this is true, try manually specifying the buildpack with "heroku buildpacks:set heroku/nodejs" (or your desired language). This should resolve most errors related to buildpack detection.

Upvotes: 2

Pandurang Yachwad
Pandurang Yachwad

Reputation: 1723

I had similar issue, here are the steps which solved the problem.

heroku buildpacks:set heroku/nodejs
git push heroku master

Basically details are in the more info link -


This situation may also occur if you remove or rename a file that previously led to the automatic detection of your application type and thus the automatic setting of the detected buildpack on your application.


Upvotes: 5

Related Questions