mirror of
https://github.com/naveenrajm7/rpmbuild.git
synced 2025-07-12 20:23:50 +00:00
Compare commits
10 Commits
Author | SHA1 | Date | |
---|---|---|---|
b52f0e593e | |||
44f3322e47 | |||
b393c528e2 | |||
ca2383e80a | |||
0241680a99 | |||
b980813ffe | |||
2c036efa4b | |||
9ee1f018db | |||
13cf204bc3 | |||
0354642598 |
@ -1,11 +1,12 @@
|
|||||||
# Using CentOS 7 with Node 12 as base image to support rpmbuild
|
# Using CentOS 7 as base image to support rpmbuild (packages will be Dist el7)
|
||||||
FROM centos:7
|
FROM centos:7
|
||||||
|
|
||||||
# Copying all contents of rpmbuild repo inside container
|
# Copying all contents of rpmbuild repo inside container
|
||||||
COPY . .
|
COPY . .
|
||||||
|
|
||||||
# Installing tools needed for rpmbuild , depends on specfile
|
# Installing tools needed for rpmbuild ,
|
||||||
RUN yum install -y rpm-build rpmdevtools gcc make coreutils
|
# depends on BuildRequires field in specfile, (TODO: take as input & install)
|
||||||
|
RUN yum install -y rpm-build rpmdevtools gcc make coreutils python
|
||||||
|
|
||||||
# Setting up node to run our JS file
|
# Setting up node to run our JS file
|
||||||
# Download Node Linux binary
|
# Download Node Linux binary
|
||||||
|
105
README.md
105
README.md
@ -8,15 +8,12 @@ Integrates easily with GitHub actions to allow RPMS to be uploaded as Artifact (
|
|||||||
### Pre-requisites
|
### Pre-requisites
|
||||||
Create a workflow `.yml` file in your repositories `.github/workflows` directory. An [example workflow](#example-workflow---build-rpm) is available below. For more information, reference the GitHub Help Documentation for [Creating a workflow file](https://help.github.com/en/articles/configuring-a-workflow#creating-a-workflow-file).
|
Create a workflow `.yml` file in your repositories `.github/workflows` directory. An [example workflow](#example-workflow---build-rpm) is available below. For more information, reference the GitHub Help Documentation for [Creating a workflow file](https://help.github.com/en/articles/configuring-a-workflow#creating-a-workflow-file).
|
||||||
|
|
||||||
This generated RPMS and SRPMS can be used in two ways.
|
**Note:** You need to have a spec file in order to build RPM.
|
||||||
1. Upload as build artifact
|
|
||||||
You can use GitHub Action [`@actions/upload-artifact`](https://www.github.com/actions/upload-artifact)
|
|
||||||
2. Upload as Release assest
|
|
||||||
If you want to upload as release asset ,You also will need to have a release to upload your asset to, which could be created programmatically by [`@actions/create-release`](https://www.github.com/actions/create-release) as show in the example workflow.
|
|
||||||
|
|
||||||
### Inputs
|
### Inputs
|
||||||
|
|
||||||
- `spec_file`: The path to the spec file in your repo. `**require**`
|
- `spec_file`: The path to the spec file in your repo. [**required**]
|
||||||
|
|
||||||
### Outputs
|
### Outputs
|
||||||
|
|
||||||
@ -26,6 +23,11 @@ This generated RPMS and SRPMS can be used in two ways.
|
|||||||
- `source_rpm_name`: name of Source RPM file
|
- `source_rpm_name`: name of Source RPM file
|
||||||
- `rpm_content_type`: Content-type for RPM Upload
|
- `rpm_content_type`: Content-type for RPM Upload
|
||||||
|
|
||||||
|
This generated RPMS and SRPMS can be used in two ways.
|
||||||
|
1. Upload as build artifact
|
||||||
|
You can use GitHub Action [`@actions/upload-artifact`](https://www.github.com/actions/upload-artifact)
|
||||||
|
2. Upload as Release assest
|
||||||
|
If you want to upload as release asset ,You also will need to have a release to upload your asset to, which could be created programmatically by [`@actions/create-release`](https://www.github.com/actions/create-release) as show in the example workflow.
|
||||||
|
|
||||||
### Example workflow - build RPM
|
### Example workflow - build RPM
|
||||||
|
|
||||||
@ -49,10 +51,97 @@ jobs:
|
|||||||
- name: Upload artifact
|
- name: Upload artifact
|
||||||
uses: actions/upload-artifact@v1.0.0
|
uses: actions/upload-artifact@v1.0.0
|
||||||
with:
|
with:
|
||||||
name: Source RPM
|
name: Binary RPM
|
||||||
path: ${{ steps.rpm.outputs.source_rpm_path }}
|
path: ${{ steps.rpm.outputs.rpm_dir_path }}
|
||||||
```
|
```
|
||||||
|
This workflow triggered on every `push` , builds RPM and Source RPM using cello.spec and contents of that git ref that triggered that action. Contents are retrived through [GitHub API](https://developer.github.com/v3/repos/contents/#get-archive-link) [downloaded through archive link].
|
||||||
|
The generated RPMs or SRPMS can be uploaded as artifacts by using actions/upload-artifact. The [outputs](#outputs) given by rpmbuild action can be used to specify path for upload action.
|
||||||
|
|
||||||
|
#### Above workflow will create an artifact like :
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
|
||||||
|
Use with Release:
|
||||||
|
```yaml
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
# Sequence of patterns matched against refs/tags
|
||||||
|
tags:
|
||||||
|
- 'v*' # Push events to matching v*, i.e. v1.0, v20.15.10
|
||||||
|
|
||||||
|
name: Create RPM Release
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
name: Create RPM Release
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
|
||||||
|
- name: Checkout code
|
||||||
|
uses: actions/checkout@master
|
||||||
|
|
||||||
|
- name: Create Release
|
||||||
|
id: create_release
|
||||||
|
uses: actions/create-release@latest
|
||||||
|
env:
|
||||||
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # This token is provided by Actions, you do not need to create your own token
|
||||||
|
with:
|
||||||
|
tag_name: ${{ github.ref }}
|
||||||
|
release_name: Release ${{ github.ref }}
|
||||||
|
body: |
|
||||||
|
Changes in this Release
|
||||||
|
- Create RPM
|
||||||
|
- Upload Source RPM
|
||||||
|
draft: false
|
||||||
|
prerelease: false
|
||||||
|
|
||||||
|
- name: build RPM package
|
||||||
|
id: rpm_build
|
||||||
|
uses: naveenrajm7/rpmbuild@master
|
||||||
|
with:
|
||||||
|
spec_file: "cello.spec"
|
||||||
|
|
||||||
|
- name: Upload Release Asset
|
||||||
|
id: upload-release-asset
|
||||||
|
uses: actions/upload-release-asset@v1
|
||||||
|
env:
|
||||||
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
with:
|
||||||
|
upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps
|
||||||
|
asset_path: ${{ steps.rpm_build.outputs.source_rpm_path }}
|
||||||
|
asset_name: ${{ steps.rpm_build.outputs.source_rpm_name }}
|
||||||
|
asset_content_type: ${{ steps.rpm_build.outputs.rpm_content_type }}
|
||||||
|
```
|
||||||
|
|
||||||
|
#### The above release uploads SRPM like :
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
Example Repository which uses rpmbuild action https://github.com/naveenrajm7/cello
|
||||||
|
|
||||||
|
Note on distribution:
|
||||||
|
If your RPMs are distribution specific like el7 or el8.
|
||||||
|
- Use naveenrajm7/rpmbuild@master for Centos7 *[el7]*
|
||||||
|
- Use naveenrajm7/rpmbuild@centos8 for Centos8 *[el8]*
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
- name: build RPM package
|
||||||
|
id: rpm_build
|
||||||
|
uses: naveenrajm7/rpmbuild@centos8
|
||||||
|
with:
|
||||||
|
spec_file: "cello.spec"
|
||||||
|
```
|
||||||
|
|
||||||
|
## References
|
||||||
|
|
||||||
|
* [RPM Packaging Guide](https://rpm-packaging-guide.github.io/)
|
||||||
|
* [GitHub Learning Lab](https://lab.github.com/)
|
||||||
|
* [Container Toolkit Action](https://github.com/actions/container-toolkit-action)
|
||||||
|
|
||||||
## License
|
## License
|
||||||
|
|
||||||
The scripts and documentation in this project are released under the [GNU GPLv3](LICENSE)
|
The scripts and documentation in this project are released under the [GNU GPLv3](LICENSE)
|
||||||
|
|
||||||
|
*Created during the GitHub Actions Hackathon 2020 :octocat: :computer: .*
|
||||||
|
@ -12,9 +12,11 @@ outputs:
|
|||||||
source_rpm_path:
|
source_rpm_path:
|
||||||
description: 'path to Source RPM file'
|
description: 'path to Source RPM file'
|
||||||
source_rpm_dir_path:
|
source_rpm_dir_path:
|
||||||
description: 'path to Source RPM directory'
|
description: 'path to SRPMS directory'
|
||||||
source_rpm_name:
|
source_rpm_name:
|
||||||
description: 'name of Source RPM file'
|
description: 'name of Source RPM file'
|
||||||
|
rpm_dir_path:
|
||||||
|
description: 'path to RPMS directory'
|
||||||
rpm_content_type:
|
rpm_content_type:
|
||||||
description: 'Content-type for Upload'
|
description: 'Content-type for Upload'
|
||||||
|
|
||||||
|
BIN
assets/upload_artifacts.png
Normal file
BIN
assets/upload_artifacts.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 28 KiB |
BIN
assets/upload_release_asset.png
Normal file
BIN
assets/upload_release_asset.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 123 KiB |
22
lib/main.js
22
lib/main.js
@ -19,6 +19,7 @@ function run() {
|
|||||||
try {
|
try {
|
||||||
// Get github context data
|
// Get github context data
|
||||||
const context = github.context;
|
const context = github.context;
|
||||||
|
// To be used to get contents of this git ref
|
||||||
const owner = context.repo.owner;
|
const owner = context.repo.owner;
|
||||||
const repo = context.repo.repo;
|
const repo = context.repo.repo;
|
||||||
const ref = context.ref;
|
const ref = context.ref;
|
||||||
@ -44,29 +45,30 @@ function run() {
|
|||||||
yield exec.exec('rpmdev-setuptree');
|
yield exec.exec('rpmdev-setuptree');
|
||||||
// Copy spec file from path specFile to /root/rpmbuild/SPECS/
|
// Copy spec file from path specFile to /root/rpmbuild/SPECS/
|
||||||
yield exec.exec(`cp /github/workspace/${specFile} /github/home/rpmbuild/SPECS/`);
|
yield exec.exec(`cp /github/workspace/${specFile} /github/home/rpmbuild/SPECS/`);
|
||||||
// Dowload tar.gz file of source code
|
// Dowload tar.gz file of source code, Reference : https://developer.github.com/v3/repos/contents/#get-archive-link
|
||||||
yield exec.exec(`curl -L --output tmp.tar.gz https://api.github.com/repos/${owner}/${repo}/tarball/${ref}`);
|
yield exec.exec(`curl -L --output tmp.tar.gz https://api.github.com/repos/${owner}/${repo}/tarball/${ref}`);
|
||||||
// create directory to match source file - name-version
|
// create directory to match source file - %{name}-{version}.tar.gz of spec file
|
||||||
yield exec.exec(`mkdir ${name}-${version}`);
|
yield exec.exec(`mkdir ${name}-${version}`);
|
||||||
// Extract source code to directory
|
// Extract source code
|
||||||
yield exec.exec(`tar xvf tmp.tar.gz -C ${name}-${version} --strip-components 1`);
|
yield exec.exec(`tar xvf tmp.tar.gz -C ${name}-${version} --strip-components 1`);
|
||||||
// Create Source tar.gz file
|
// Create Source tar.gz file
|
||||||
yield exec.exec(`tar -czvf ${name}-${version}.tar.gz ${name}-${version}`);
|
yield exec.exec(`tar -czvf ${name}-${version}.tar.gz ${name}-${version}`);
|
||||||
// Get repo files from /github/workspace/
|
// // list files in current directory /github/workspace/
|
||||||
yield exec.exec('ls -la ');
|
// await exec.exec('ls -la ');
|
||||||
// Copy tar.gz file to source
|
// Copy tar.gz file to source path
|
||||||
yield exec.exec(`cp ${name}-${version}.tar.gz /github/home/rpmbuild/SOURCES/`);
|
yield exec.exec(`cp ${name}-${version}.tar.gz /github/home/rpmbuild/SOURCES/`);
|
||||||
// Execute rpmbuild
|
// Execute rpmbuild , -ba generates both RPMS and SPRMS
|
||||||
try {
|
try {
|
||||||
yield exec.exec(`rpmbuild -ba /github/home/rpmbuild/SPECS/${specFile}`);
|
yield exec.exec(`rpmbuild -ba /github/home/rpmbuild/SPECS/${specFile}`);
|
||||||
}
|
}
|
||||||
catch (err) {
|
catch (err) {
|
||||||
core.setFailed(`action failed with error: ${err}`);
|
core.setFailed(`action failed with error: ${err}`);
|
||||||
}
|
}
|
||||||
// Verify RPM created
|
// Verify RPM is created
|
||||||
yield exec.exec('ls /github/home/rpmbuild/RPMS');
|
yield exec.exec('ls /github/home/rpmbuild/RPMS');
|
||||||
// setOutput rpm_path to /root/rpmbuild/RPMS , to be consumed by other actions like
|
// setOutput rpm_path to /root/rpmbuild/RPMS , to be consumed by other actions like
|
||||||
// actions/upload-release-asset
|
// actions/upload-release-asset
|
||||||
|
// Get source rpm name , to provide file name, path as output
|
||||||
let myOutput = '';
|
let myOutput = '';
|
||||||
yield cp.exec('ls /github/home/rpmbuild/SRPMS/', (err, stdout, stderr) => {
|
yield cp.exec('ls /github/home/rpmbuild/SRPMS/', (err, stdout, stderr) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
@ -81,14 +83,14 @@ function run() {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
// only contents of workspace can be changed by actions and used by subsequent actions
|
// only contents of workspace can be changed by actions and used by subsequent actions
|
||||||
// So copy all generated rpms into workspace , and publish output path relative to workspace
|
// So copy all generated rpms into workspace , and publish output path relative to workspace (/github/workspace)
|
||||||
yield exec.exec(`mkdir -p rpmbuild/SRPMS`);
|
yield exec.exec(`mkdir -p rpmbuild/SRPMS`);
|
||||||
yield exec.exec(`mkdir -p rpmbuild/RPMS`);
|
yield exec.exec(`mkdir -p rpmbuild/RPMS`);
|
||||||
yield exec.exec(`cp /github/home/rpmbuild/SRPMS/${myOutput} rpmbuild/SRPMS`);
|
yield exec.exec(`cp /github/home/rpmbuild/SRPMS/${myOutput} rpmbuild/SRPMS`);
|
||||||
yield cp.exec(`cp -R /github/home/rpmbuild/RPMS/. rpmbuild/RPMS/`);
|
yield cp.exec(`cp -R /github/home/rpmbuild/RPMS/. rpmbuild/RPMS/`);
|
||||||
yield exec.exec(`ls -la rpmbuild/SRPMS`);
|
yield exec.exec(`ls -la rpmbuild/SRPMS`);
|
||||||
yield exec.exec(`ls -la rpmbuild/RPMS`);
|
yield exec.exec(`ls -la rpmbuild/RPMS`);
|
||||||
// set output to path relative to workspace ex ./rpm/
|
// set outputs to path relative to workspace ex ./rpmbuild/
|
||||||
core.setOutput("source_rpm_dir_path", `rpmbuild/SRPMS/`); // path to SRPMS directory
|
core.setOutput("source_rpm_dir_path", `rpmbuild/SRPMS/`); // path to SRPMS directory
|
||||||
core.setOutput("source_rpm_path", `rpmbuild/SRPMS/${myOutput}`); // path to Source RPM file
|
core.setOutput("source_rpm_path", `rpmbuild/SRPMS/${myOutput}`); // path to Source RPM file
|
||||||
core.setOutput("source_rpm_name", `${myOutput}`); // name of Source RPM file
|
core.setOutput("source_rpm_name", `${myOutput}`); // name of Source RPM file
|
||||||
|
@ -1,43 +0,0 @@
|
|||||||
const { Octokit } = require('@octokit/rest');
|
|
||||||
//const fs = require('fs');
|
|
||||||
const tc = require('@actions/tool-cache');
|
|
||||||
|
|
||||||
|
|
||||||
async function download_archive(owner, repo, ref ) {
|
|
||||||
try {
|
|
||||||
|
|
||||||
const octokit = new Octokit();
|
|
||||||
|
|
||||||
const archive_format = "tarball";
|
|
||||||
|
|
||||||
const tag = "v1.0.0"
|
|
||||||
|
|
||||||
const tarFile = `${repo}-1.0.tar.gz`;
|
|
||||||
|
|
||||||
console.log("Calling API ...");
|
|
||||||
await octokit.repos.getArchiveLink({
|
|
||||||
owner,
|
|
||||||
repo,
|
|
||||||
archive_format,
|
|
||||||
ref
|
|
||||||
}).then(( { data }) => {
|
|
||||||
fs.writeFile(tarFile, Buffer.from(data), function(err){
|
|
||||||
if(err) {
|
|
||||||
return console.log(err);
|
|
||||||
}
|
|
||||||
console.log("The Tar file was saved!");
|
|
||||||
console.log(`Tarball Location : ${tarFile}`);
|
|
||||||
return tarFile;
|
|
||||||
});
|
|
||||||
}).catch( function(error){
|
|
||||||
console.log(error);
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
} catch (error) {
|
|
||||||
core.setFailed(error.message);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
module.exports = download_archive;
|
|
25
src/main.ts
25
src/main.ts
@ -11,6 +11,7 @@ async function run() {
|
|||||||
// Get github context data
|
// Get github context data
|
||||||
const context = github.context;
|
const context = github.context;
|
||||||
|
|
||||||
|
// To be used to get contents of this git ref
|
||||||
const owner = context.repo.owner
|
const owner = context.repo.owner
|
||||||
const repo = context.repo.repo
|
const repo = context.repo.repo
|
||||||
const ref = context.ref
|
const ref = context.ref
|
||||||
@ -42,24 +43,25 @@ async function run() {
|
|||||||
// Copy spec file from path specFile to /root/rpmbuild/SPECS/
|
// Copy spec file from path specFile to /root/rpmbuild/SPECS/
|
||||||
await exec.exec(`cp /github/workspace/${specFile} /github/home/rpmbuild/SPECS/`);
|
await exec.exec(`cp /github/workspace/${specFile} /github/home/rpmbuild/SPECS/`);
|
||||||
|
|
||||||
// Dowload tar.gz file of source code
|
// Dowload tar.gz file of source code, Reference : https://developer.github.com/v3/repos/contents/#get-archive-link
|
||||||
await exec.exec(`curl -L --output tmp.tar.gz https://api.github.com/repos/${owner}/${repo}/tarball/${ref}`)
|
await exec.exec(`curl -L --output tmp.tar.gz https://api.github.com/repos/${owner}/${repo}/tarball/${ref}`)
|
||||||
|
|
||||||
// create directory to match source file - name-version
|
// create directory to match source file - %{name}-{version}.tar.gz of spec file
|
||||||
await exec.exec(`mkdir ${name}-${version}`);
|
await exec.exec(`mkdir ${name}-${version}`);
|
||||||
|
|
||||||
// Extract source code to directory
|
// Extract source code
|
||||||
await exec.exec(`tar xvf tmp.tar.gz -C ${name}-${version} --strip-components 1`);
|
await exec.exec(`tar xvf tmp.tar.gz -C ${name}-${version} --strip-components 1`);
|
||||||
|
|
||||||
// Create Source tar.gz file
|
// Create Source tar.gz file
|
||||||
await exec.exec(`tar -czvf ${name}-${version}.tar.gz ${name}-${version}`);
|
await exec.exec(`tar -czvf ${name}-${version}.tar.gz ${name}-${version}`);
|
||||||
|
|
||||||
// Get repo files from /github/workspace/
|
// // list files in current directory /github/workspace/
|
||||||
await exec.exec('ls -la ');
|
// await exec.exec('ls -la ');
|
||||||
// Copy tar.gz file to source
|
|
||||||
|
// Copy tar.gz file to source path
|
||||||
await exec.exec(`cp ${name}-${version}.tar.gz /github/home/rpmbuild/SOURCES/`);
|
await exec.exec(`cp ${name}-${version}.tar.gz /github/home/rpmbuild/SOURCES/`);
|
||||||
|
|
||||||
// Execute rpmbuild
|
// Execute rpmbuild , -ba generates both RPMS and SPRMS
|
||||||
try {
|
try {
|
||||||
await exec.exec(
|
await exec.exec(
|
||||||
`rpmbuild -ba /github/home/rpmbuild/SPECS/${specFile}`
|
`rpmbuild -ba /github/home/rpmbuild/SPECS/${specFile}`
|
||||||
@ -68,12 +70,13 @@ async function run() {
|
|||||||
core.setFailed(`action failed with error: ${err}`);
|
core.setFailed(`action failed with error: ${err}`);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Verify RPM created
|
// Verify RPM is created
|
||||||
await exec.exec('ls /github/home/rpmbuild/RPMS');
|
await exec.exec('ls /github/home/rpmbuild/RPMS');
|
||||||
|
|
||||||
// setOutput rpm_path to /root/rpmbuild/RPMS , to be consumed by other actions like
|
// setOutput rpm_path to /root/rpmbuild/RPMS , to be consumed by other actions like
|
||||||
// actions/upload-release-asset
|
// actions/upload-release-asset
|
||||||
|
|
||||||
|
// Get source rpm name , to provide file name, path as output
|
||||||
let myOutput = '';
|
let myOutput = '';
|
||||||
await cp.exec('ls /github/home/rpmbuild/SRPMS/', (err, stdout, stderr) => {
|
await cp.exec('ls /github/home/rpmbuild/SRPMS/', (err, stdout, stderr) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
@ -89,7 +92,7 @@ async function run() {
|
|||||||
|
|
||||||
|
|
||||||
// only contents of workspace can be changed by actions and used by subsequent actions
|
// only contents of workspace can be changed by actions and used by subsequent actions
|
||||||
// So copy all generated rpms into workspace , and publish output path relative to workspace
|
// So copy all generated rpms into workspace , and publish output path relative to workspace (/github/workspace)
|
||||||
await exec.exec(`mkdir -p rpmbuild/SRPMS`);
|
await exec.exec(`mkdir -p rpmbuild/SRPMS`);
|
||||||
await exec.exec(`mkdir -p rpmbuild/RPMS`);
|
await exec.exec(`mkdir -p rpmbuild/RPMS`);
|
||||||
|
|
||||||
@ -99,13 +102,11 @@ async function run() {
|
|||||||
await exec.exec(`ls -la rpmbuild/SRPMS`);
|
await exec.exec(`ls -la rpmbuild/SRPMS`);
|
||||||
await exec.exec(`ls -la rpmbuild/RPMS`);
|
await exec.exec(`ls -la rpmbuild/RPMS`);
|
||||||
|
|
||||||
// set output to path relative to workspace ex ./rpm/
|
// set outputs to path relative to workspace ex ./rpmbuild/
|
||||||
core.setOutput("source_rpm_dir_path", `rpmbuild/SRPMS/`); // path to SRPMS directory
|
core.setOutput("source_rpm_dir_path", `rpmbuild/SRPMS/`); // path to SRPMS directory
|
||||||
core.setOutput("source_rpm_path", `rpmbuild/SRPMS/${myOutput}`); // path to Source RPM file
|
core.setOutput("source_rpm_path", `rpmbuild/SRPMS/${myOutput}`); // path to Source RPM file
|
||||||
core.setOutput("source_rpm_name", `${myOutput}`); // name of Source RPM file
|
core.setOutput("source_rpm_name", `${myOutput}`); // name of Source RPM file
|
||||||
|
|
||||||
core.setOutput("rpm_dir_path", `rpmbuild/RPMS/`); // path to RPMS directory
|
core.setOutput("rpm_dir_path", `rpmbuild/RPMS/`); // path to RPMS directory
|
||||||
|
|
||||||
core.setOutput("rpm_content_type", "application/octet-stream"); // Content-type for Upload
|
core.setOutput("rpm_content_type", "application/octet-stream"); // Content-type for Upload
|
||||||
|
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user