Skip to content

Commit

Permalink
Add ARM support for NodeJS (#1499)
Browse files Browse the repository at this point in the history
* ARM support for NodeJS

* Changelog whitespace

* Inject architecture

Relying on the format of RUBY_PLATFORM is a little surprising. This allows us to test if we want and reuses the existing architecture logic for consistency.

* Update changelog link

* Test node installer with all known architectures

* Apply suggestions from code review

Co-authored-by: Ed Morley <[email protected]>

---------

Co-authored-by: Matt Larraz <[email protected]>
Co-authored-by: Ed Morley <[email protected]>
  • Loading branch information
3 people authored Oct 8, 2024
1 parent 081297f commit 56199b2
Show file tree
Hide file tree
Showing 5 changed files with 18 additions and 19 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

## [Unreleased]

- Support Node.js on ARM builds (https://github.com/heroku/heroku-buildpack-ruby/pull/1499)

## [v280] - 2024-10-08

Expand Down
11 changes: 3 additions & 8 deletions lib/language_pack/helpers/node_installer.rb
Original file line number Diff line number Diff line change
@@ -1,15 +1,15 @@
class LanguagePack::Helpers::NodeInstaller
attr_reader :version

def initialize
nodebin = LanguagePack::Helpers::Nodebin.node_lts
def initialize(arch: )
nodebin = LanguagePack::Helpers::Nodebin.node_lts(arch: arch)
@version = nodebin["number"]
@url = nodebin["url"]
@fetcher = LanguagePack::Fetcher.new("")
end

def binary_path
node_folder(@version)
File.basename(@url).delete_suffix(".tar.gz")
end

def install
Expand All @@ -27,9 +27,4 @@ def install
FileUtils.mv("#{dir}/#{node_bin}", ".")
end
end

private
def node_folder(version)
"node-v#{version}-linux-x64"
end
end
9 changes: 5 additions & 4 deletions lib/language_pack/helpers/nodebin.rb
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,11 @@ class LanguagePack::Helpers::Nodebin
NODE_VERSION = "20.9.0"
YARN_VERSION = "1.22.19"

def self.hardcoded_node_lts
def self.hardcoded_node_lts(arch: )
arch = "x64" if arch == "amd64"
{
"number" => NODE_VERSION,
"url" => "https://heroku-nodebin.s3.us-east-1.amazonaws.com/node/release/linux-x64/node-v#{NODE_VERSION}-linux-x64.tar.gz"
"url" => "https://nodejs.org/download/release/v#{NODE_VERSION}/node-v#{NODE_VERSION}-linux-#{arch}.tar.gz",
}
end

Expand All @@ -18,8 +19,8 @@ def self.hardcoded_yarn
}
end

def self.node_lts
hardcoded_node_lts
def self.node_lts(arch: )
hardcoded_node_lts(arch: arch)
end

def self.yarn
Expand Down
2 changes: 1 addition & 1 deletion lib/language_pack/ruby.rb
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ def bundler

def initialize(*args)
super(*args)
@node_installer = LanguagePack::Helpers::NodeInstaller.new
@node_installer = LanguagePack::Helpers::NodeInstaller.new(arch: @arch)
@yarn_installer = LanguagePack::Helpers::YarnInstaller.new
end

Expand Down
14 changes: 8 additions & 6 deletions spec/helpers/node_installer_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,15 @@

describe LanguagePack::Helpers::NodeInstaller do
describe "#install" do
it "should extract a node binary" do
Dir.mktmpdir do |dir|
Dir.chdir(dir) do
installer = LanguagePack::Helpers::NodeInstaller.new
installer.install
LanguagePack::Base::KNOWN_ARCHITECTURES.each do |arch|
it "should extract a node binary on #{arch}" do
Dir.mktmpdir do |dir|
Dir.chdir(dir) do
installer = LanguagePack::Helpers::NodeInstaller.new(arch: "arm64")
installer.install

expect(File.exist?("node")).to be(true)
expect(File.exist?("node")).to be(true)
end
end
end
end
Expand Down

0 comments on commit 56199b2

Please sign in to comment.