jpackage Are the RPM Requires necessary?

Alexey Semenyuk alexey.semenyuk at oracle.com
Thu Mar 26 20:27:37 UTC 2020



On 3/26/2020 4:13 PM, Sverre Moe wrote:
> tor. 26. mar. 2020 kl. 20:41 skrev Alexey Semenyuk 
> <alexey.semenyuk at oracle.com <mailto:alexey.semenyuk at oracle.com>>:
>
>
>
>     On 3/26/2020 11:17 AM, Sverre Moe wrote:
>     > Running jpackage to build an RPM will add some Requires to the
>     package.
>     >
>     > It comes from the Template file:
>     >
>     https://github.com/openjdk/jdk/blob/jdk-14%2B36/src/jdk.incubator.jpackage/linux/classes/jdk/incubator/jpackage/internal/resources/template.spec
>     <https://urldefense.com/v3/__https://github.com/openjdk/jdk/blob/jdk-14*2B36/src/jdk.incubator.jpackage/linux/classes/jdk/incubator/jpackage/internal/resources/template.spec__;JQ!!GqivPVa7Brio!M9XkBzPXiKm1ZIWttGJG4VL4Wf0-KGz9x6MXZQGaSDqz64B9k-Uh1JtNLScPm0aHPUWS$>
>     >
>     > Autoprov: 0
>     > Autoreq: 0
>     > %if "xPACKAGE_DEFAULT_DEPENDENCIES" != x ||
>     "xPACKAGE_CUSTOM_DEPENDENCIES"
>     > != x
>     > Requires: PACKAGE_DEFAULT_DEPENDENCIES PACKAGE_CUSTOM_DEPENDENCIES
>     > %endif
>     >
>     > Building on OpenSUSE will give us these Requires:
>     > +%if "xglibc, libX11-6, libXau6, libXext6, libXi6, libXrender1,
>     libXtst6,
>     > libasound2, libxcb1, libz1" != x || "x" != x
>     > +Requires: glibc, libX11-6, libXau6, libXext6, libXi6, libXrender1,
>     > libXtst6, libasound2, libxcb1, libz1
>     > +%endif
>     > +
>     > +#avoid ARCH subfolder
>     >
>     > We override the RPM spec file with resource directory. I copied
>     the RPM
>     > spec file content from the one jpackage generated and added
>     something extra
>     > to it.
>     >
>     > Unfortunately this RPM will not install on Fedora, but installs
>     fine on
>     > OpenSUSE where I built it.
>     >
>     > Installing on Fedora will spew out this line for all these Requires.
>     > nothing provides libX11-6
>     >
>     > Are these Requires needed by Java?
>     Yes. The list of required packages is built automatically by
>     jpackage by
>     analyzing dependencies of dynamic libraries of JRE bundled with the
>     application being packed.
>     On different distributes the same package can have different names.
>     Seems like the package that is named on OpenSuSE as ' libX11-6' is
>     named
>     as 'libX11' on Fedora.
>
>
> Not all Requires for OpenSUSE had an equivalent Fedoroa Requires
>
> Requires for OpenSUSE from jpackage
> Requires: glibc, libX11-6, libXau6, libXext6, libXi6, libXrender1, 
> libXtst6, libasound2, libxcb1, libz1
>
> Requires for Fedora from jpackage:
> Requires: glibc, libX11, libXau, libXext, libXi, libXrender, libXtst, 
> libxcbs
>
> The RPM spec for Fedora does not get any Requires with libasound and libz.
Probably this is because these packages are not installed on Fedora host 
where you run jpackage.

>     > What is the consequences if these are
>     > not available on the system installing the RPM?
>     Installation will fail.
>
> Yes of course, if it has Requires and the Requires is not present, 
> that is the problem we now got on Fedora for the installer built in 
> OpenSUSE.
> However, if I omit all these Requires, then RPM will install/unpackage 
> the application just fine. What you are saying if any of these 
> Requires is not present then the install/unpack of the RPM will fail?
Correct. Sorry for the confusion.

> So these Requires are only necessary for the RPM installation process?
Yes.

>
> We previously uses jpackager, and did not specify these Requires when 
> building the installer. Installation worked fine though on both 
> OpenSUSE and Fedore. Probably because these Requires where installed 
> as default on those systems.
If installed app depends on missing packages it will fail to operate. 
The idea of providing the list of required packages is to verify the app 
will run at installation phase.

- Alexey
> /Sverre



More information about the core-libs-dev mailing list