| [934] | 1 | This document is a how-to for building new packaages for scripts.mit.edu. | 
|---|
|  | 2 |  | 
|---|
| [1353] | 3 | Prerequisites | 
|---|
|  | 4 | ============= | 
|---|
| [934] | 5 |  | 
|---|
| [1353] | 6 | * A trusted scripts.mit.edu server | 
|---|
|  | 7 | * A scripts-build account on that server (but that was created when it | 
|---|
|  | 8 | was installed, or something's wrong) | 
|---|
|  | 9 | * A set of personal credentials for the scripts svn repo | 
|---|
| [934] | 10 |  | 
|---|
| [1353] | 11 | Directions | 
|---|
|  | 12 | ========== | 
|---|
| [934] | 13 |  | 
|---|
| [1353] | 14 | * Log into the server as root | 
|---|
| [934] | 15 |  | 
|---|
| [1353] | 16 | * /bin/su scripts-build # It's a bad idea to build as root.  This is | 
|---|
|  | 17 | # less urgent than it used to be, because you'll | 
|---|
|  | 18 | # be building using mock in a chroot, but it's | 
|---|
|  | 19 | # still good habit.  Also, if you work in | 
|---|
|  | 20 | # /srv/repository as root, scripts-build won't | 
|---|
|  | 21 | # be able to change some of the resulting files | 
|---|
|  | 22 |  | 
|---|
|  | 23 | * cd /srv/repository | 
|---|
|  | 24 |  | 
|---|
|  | 25 | * svn up  # Important both to build with current code, and because the | 
|---|
|  | 26 | # svn revision becomes part of the package release number, | 
|---|
|  | 27 | # and you can infer whether changes in the code were made | 
|---|
|  | 28 | # before or after a particular build by looking at the package | 
|---|
|  | 29 | # and svn release/revision. | 
|---|
|  | 30 |  | 
|---|
|  | 31 | * cd server/fedora | 
|---|
|  | 32 |  | 
|---|
|  | 33 | * # Look in the .dload directory.  If you want to build with a newer | 
|---|
|  | 34 | # version of any upstream packages that are there, then | 
|---|
|  | 35 | * rm .dload/[OLD-PACKAGES].src.rpm # It's fine to delete all SRPMs here | 
|---|
|  | 36 | * rm download_stamp | 
|---|
|  | 37 |  | 
|---|
|  | 38 | * make [PACKAGE-YOU-WANT] # e.g. 'make httpd' builds Apache with our patches | 
|---|
|  | 39 | # Note that openafs-devel is a build-dependency of accountadm, so if | 
|---|
|  | 40 | # this is a new Fedora release being bootstrapped, you'll have to | 
|---|
|  | 41 | # build openafs and install its -devel package before building accountadm | 
|---|
|  | 42 |  | 
|---|
|  | 43 | * # If the build succeeds, the mock logs, build log, binary and SRPMs | 
|---|
|  | 44 | # will be in /var/lib/mock/fedora-[RELEASE]-{x86_64|i386}/result (note that | 
|---|
|  | 45 | # this will be cleared out each time you start a new build, so if | 
|---|
|  | 46 | # you're building several packages in succession, copy the results | 
|---|
|  | 47 | # somewhere safe after each build to preserve them) | 
|---|
|  | 48 | # Add the packages to the repository by using a trusted machine and | 
|---|
| [2487] | 49 | krootscp root@[BUILD-SERVER]:/var/lib/mock/fedora-[RELEASE]-{x86_64|i386}/result /mit/scripts/yum-repos/rpm-fc[RELEASE] | 
|---|
| [1353] | 50 |  | 
|---|
| [2487] | 51 | # There has been some historic discussion about whether SRPMs should be | 
|---|
|  | 52 | # added to the repository. At this point, the standard is to include them. | 
|---|
|  | 53 |  | 
|---|
| [1353] | 54 | * # Rebuild the repo metadata to include the new packages. | 
|---|
| [2066] | 55 | cd /mit/scripts/yum-repos/rpm-fc[RELEASE] | 
|---|
| [1353] | 56 | # If you have a trusted machine: | 
|---|
| [2066] | 57 | createrepo -d . | 
|---|
| [1353] | 58 | # Otherwise, on a scripts server, as root: | 
|---|
|  | 59 | mkdir /root/repodata-YYYYMMDD # Or any suitable temp directory | 
|---|
| [2066] | 60 | createrepo -d -o /root/repodata-YYYYMMDD . | 
|---|
| [1353] | 61 | # Then from your trusted machine | 
|---|
| [2487] | 62 | krootscp -r root@[BUILD-SERVER]:/root/repodata-YYYYMMDD /mit/scripts/yum-repos/rpm-fc[RELEASE] | 
|---|
| [1353] | 63 | # Sanity check the files, and then replace the current repodata directory | 
|---|
|  | 64 | # with the one in repodata-YYYYMMDD. | 
|---|
|  | 65 |  | 
|---|
|  | 66 | Patching packages | 
|---|
|  | 67 | ================= | 
|---|
|  | 68 |  | 
|---|
|  | 69 | * To make changes to the packages that we are the upstream maintainers | 
|---|
|  | 70 | of (that is, the packages that the Scripts Team wrote): | 
|---|
|  | 71 | * The authoritative source lives in server/common/oursrc/[PACKAGE] | 
|---|
|  | 72 | * The RPM spec file is server/fedora/specs/[PACAKGE].spec | 
|---|
|  | 73 | * You directly make the relevant changes to those files, commit to | 
|---|
|  | 74 | svn, and then rebuild the package as above to include the new changes. | 
|---|
|  | 75 |  | 
|---|
|  | 76 | * To make changes to the upstream packages that we "scriptsify": | 
|---|
|  | 77 |  | 
|---|
| [1558] | 78 | * If we haven't previously scriptsified this package, you'll need | 
|---|
|  | 79 | to add it to the upstream_yum line in SVN/server/fedora/Makefile, | 
|---|
|  | 80 | and remove the download_stamp file so that it gets fetched next | 
|---|
|  | 81 | time you run 'make [PACKAGE]'. | 
|---|
|  | 82 |  | 
|---|
| [1353] | 83 | * The authoritative upstream source comes from the SRPM in the upstream | 
|---|
|  | 84 | yum repo, or in odd cases like openafs, from some other URL.  When | 
|---|
|  | 85 | you 'make [PACKAGE]' in SVN/server/fedora, if download_stamp has | 
|---|
|  | 86 | been removed, the SRPMs are all refetched into | 
|---|
|  | 87 | SVN/server/fedora/.dload, and then installed with 'rpm -i'.  This | 
|---|
|  | 88 | results in the source patches, and tarballs landing in ~/rpmbuild/SOURCES | 
|---|
|  | 89 | and the spec files landing in ~/rpmbuild/SPECS.  You can also | 
|---|
|  | 90 | manually get individual SRPMs for a package by doing this (these | 
|---|
|  | 91 | steps work fine as a mortal user, including the 'rpm -i'): | 
|---|
|  | 92 | * yumdownloader --source [PACKAGE] | 
|---|
|  | 93 | # That deposits [PACKAGE]-[VER]-[RELEASE].src.rpm in the current dir | 
|---|
|  | 94 | * rpm -i [PACAKGE]-[VER]-[RELEASE].src.rpm | 
|---|
|  | 95 | # That unpacks the SRPM, placing the source tarball and patches in | 
|---|
|  | 96 | # ~/rpmbuild/SOURCES and the spec file in ~/rpmbuild/SPECS; it | 
|---|
|  | 97 | # does *not* globally install anything, and doesn't require root | 
|---|
|  | 98 | If you prefer to not install the file, you can simply extract it | 
|---|
|  | 99 | into a directory by running: | 
|---|
|  | 100 | * /mit/ghudson/scripts/rpmx [PACKAGE]-[VER]-[RELEASE].src.rpm | 
|---|
|  | 101 |  | 
|---|
|  | 102 | * If you develop a patch to the upstream source, you should save a | 
|---|
|  | 103 | diff with your changes and add it to the repo as | 
|---|
|  | 104 | SVN/server/common/patches/[PACKAGE]-[SHORT_DESCRIPTIVE_STRING].patch | 
|---|
|  | 105 |  | 
|---|
|  | 106 | * To cause your patch to be applied when the package is built, you | 
|---|
|  | 107 | will need to save a copy of the original spec file for the upstream | 
|---|
|  | 108 | package, then modify it to add a line like: | 
|---|
|  | 109 | Patch[NUM]: [PACKAGE]-[SHORT_DESCRIPTOVE_STRING].patch | 
|---|
|  | 110 | # This should generally go after the last existing Patch line | 
|---|
|  | 111 | # in the file, and [NUM] should be significantly larger than | 
|---|
|  | 112 | # the upstream Fedora patches, to avoid conflicts later.  This | 
|---|
|  | 113 | # line tells rpmbuild where the contents of the patch live. | 
|---|
|  | 114 | You also add a line like: | 
|---|
|  | 115 | %patch[NUM] -p1 -b .[SHORT_DESCRIPTIVE_STRING] | 
|---|
|  | 116 | # This should generally go after the last existing %patch line | 
|---|
|  | 117 | # in the file, [NUM] should be the same as in the Patch line, and | 
|---|
|  | 118 | # tells rpmbuild that this is the point at which to actually apply | 
|---|
|  | 119 | # the patch | 
|---|
|  | 120 |  | 
|---|
|  | 121 | * The Release tag in the spec file should have ".scripts.%{scriptsversion} | 
|---|
|  | 122 | inserted into it just before %{?dist}, or at the end of the release | 
|---|
|  | 123 | if %{?dist} is unused. | 
|---|
|  | 124 | # e.g.          Release: 1%{?dist} | 
|---|
|  | 125 | # changes to    Release: 1.scripts.%{scriptsversion}%{?dist} | 
|---|
|  | 126 | This causes the package version to include the string "scripts" | 
|---|
|  | 127 | and our SVN revision number (which is set by the Makefile) for | 
|---|
|  | 128 | easy identification (this version will also be greater than the | 
|---|
|  | 129 | upstream version, so the system will prefer to update to it). | 
|---|
|  | 130 |  | 
|---|
|  | 131 | * If the scriptsified version of the package needs to be installed | 
|---|
|  | 132 | on the servers, and a new upstream version would break scripts | 
|---|
|  | 133 | without our changes, add a line like this: | 
|---|
|  | 134 | Provides: scripts-[PACKAGE] | 
|---|
|  | 135 | and correspondingly, add "scripts-[PACKAGE]" to the Requires line | 
|---|
|  | 136 | in SVN/server/fedora/specs/scripts-base.spec (and remember to | 
|---|
|  | 137 | build, upload, and deploy a new scripts-base package) | 
|---|
|  | 138 |  | 
|---|
|  | 139 | * Though we're not always good about it, do feel encouraged to add | 
|---|
|  | 140 | an entry at the top of the %changelog section near the bottom of | 
|---|
|  | 141 | the spec file explaining your modifications | 
|---|
|  | 142 |  | 
|---|
|  | 143 | * When you're finished with the updates to the upstream spec file, | 
|---|
|  | 144 | create a diff from the upstream spec file to your new version, | 
|---|
|  | 145 | and add it to the SVN repo as | 
|---|
|  | 146 | SVN/server/fedora/specs/[PACKAGE].spec.patch | 
|---|
| [1558] | 147 | Make sure to copy it there before you try to build the package, | 
|---|
|  | 148 | since if you don't mock will use the original specfile (and | 
|---|
|  | 149 | overwrite any changes you made in place). | 
|---|
| [1353] | 150 |  | 
|---|
| [1712] | 151 | Replacing the source of packages | 
|---|
|  | 152 | =============================== | 
|---|
|  | 153 |  | 
|---|
|  | 154 | * Patch the specfile to have an alternate Source0 (or SourceX) URL | 
|---|
|  | 155 | pointing to the updated source of the package.  You will then | 
|---|
|  | 156 | need to add a spectool line to the Makefile to ensure this new | 
|---|
|  | 157 | source gets downloaded on build: | 
|---|
|  | 158 | spectool -g -R $(specs)/PACKAGE-NAME.spec | 
|---|
|  | 159 |  | 
|---|
| [1693] | 160 | Tips | 
|---|
|  | 161 | ==== | 
|---|
|  | 162 |  | 
|---|
|  | 163 | * Don't try to build a 32-bit package without building the 64-bit | 
|---|
|  | 164 | package as well. | 
|---|