package news import ( "context" "io/ioutil" "net/http" "os" "testing" "time" "github.com/bradleyjkemp/cupaloy" "github.com/stretchr/testify/assert" "gopkg.in/h2non/gock.v1" ) const sampleNews = ` Arch Linux: Recent news updateshttps://www.archlinux.org/news/The latest and greatest news from the Arch Linux distribution.en-usTue, 14 Apr 2020 16:30:32 +0000zn_poly 0.9.2-2 update requires manual interventionhttps://www.archlinux.org/news/zn_poly-092-2-update-requires-manual-intervention/<p>The zn_poly package prior to version 0.9.2-2 was missing a soname link. This has been fixed in 0.9.2-2, so the upgrade will need to overwrite the untracked files created by ldconfig. If you get an error</p> <pre><code>zn_poly: /usr/lib/libzn_poly-0.9.so exists in filesystem </code></pre> <p>when updating, use</p> <pre><code>pacman -Syu --overwrite usr/lib/libzn_poly-0.9.so </code></pre> <p>to perform the upgrade.</p>Antonio RojasTue, 14 Apr 2020 16:30:30 +0000tag:www.archlinux.org,2020-04-14:/news/zn_poly-092-2-update-requires-manual-intervention/nss>=3.51.1-1 and lib32-nss>=3.51.1-1 updates require manual interventionhttps://www.archlinux.org/news/nss3511-1-and-lib32-nss3511-1-updates-require-manual-intervention/<p>The nss and lib32-nss packages prior to version 3.51.1-1 were missing a soname link each. This has been fixed in 3.51.1-1, so the upgrade will need to overwrite the untracked files created by ldconfig. If you get any of these errors</p> <pre><code>nss: /usr/lib/p11-kit-trust.so exists in filesystem lib32-nss: /usr/lib32/p11-kit-trust.so exists in filesystem </code></pre> <p>when updating, use</p> <pre><code>pacman -Syu --overwrite /usr/lib\*/p11-kit-trust.so </code></pre> <p>to perform the upgrade.</p>Jan Alexander SteffensMon, 13 Apr 2020 00:35:58 +0000tag:www.archlinux.org,2020-04-13:/news/nss3511-1-and-lib32-nss3511-1-updates-require-manual-intervention/hplip 3.20.3-2 update requires manual interventionhttps://www.archlinux.org/news/hplip-3203-2-update-requires-manual-intervention/<p>The hplip package prior to version 3.20.3-2 was missing the compiled python modules. This has been fixed in 3.20.3-2, so the upgrade will need to overwrite the untracked pyc files that were created. If you get errors such as these</p> <pre><code>hplip: /usr/share/hplip/base/__pycache__/__init__.cpython-38.pyc exists in filesystem hplip: /usr/share/hplip/base/__pycache__/avahi.cpython-38.pyc exists in filesystem hplip: /usr/share/hplip/base/__pycache__/codes.cpython-38.pyc exists in filesystem ...many more... </code></pre> <p>when updating, use</p> <pre><code>pacman -Suy --overwrite /usr/share/hplip/\* </code></pre> <p>to perform the upgrade.</p>Andreas RadkeThu, 19 Mar 2020 06:53:30 +0000tag:www.archlinux.org,2020-03-19:/news/hplip-3203-2-update-requires-manual-intervention/firewalld>=0.8.1-2 update requires manual interventionhttps://www.archlinux.org/news/firewalld081-2-update-requires-manual-intervention/<p>The firewalld package prior to version 0.8.1-2 was missing the compiled python modules. This has been fixed in 0.8.1-2, so the upgrade will need to overwrite the untracked pyc files created. If you get errors like these</p> <pre><code>firewalld: /usr/lib/python3.8/site-packages/firewall/__pycache__/__init__.cpython-38.pyc exists in filesystem firewalld: /usr/lib/python3.8/site-packages/firewall/__pycache__/client.cpython-38.pyc exists in filesystem firewalld: /usr/lib/python3.8/site-packages/firewall/__pycache__/dbus_utils.cpython-38.pyc exists in filesystem ...many more... </code></pre> <p>when updating, use</p> <pre><code>pacman -Suy --overwrite /usr/lib/python3.8/site-packages/firewall/\* </code></pre> <p>to perform the upgrade.</p>Jan Alexander SteffensSun, 01 Mar 2020 16:36:48 +0000tag:www.archlinux.org,2020-03-01:/news/firewalld081-2-update-requires-manual-intervention/The Future of the Arch Linux Project Leaderhttps://www.archlinux.org/news/the-future-of-the-arch-linux-project-leader/<p>Hello everyone,</p> <p>Some of you may know me from the days when I was much more involved in Arch, but most of you probably just know me as a name on the website. I’ve been with Arch for some time, taking the leadership of this beast over from Judd back in 2007. But, as these things often go, my involvement has slid down to minimal levels over time. It’s high time that changes.</p> <p>Arch Linux needs involved leadership to make hard decisions and direct the project where it needs to go. And I am not in a position to do this.</p> <p>In a team effort, the Arch Linux staff devised a new process for determining future leaders. From now on, leaders will be elected by the staff for a term length of two years. Details of this new process can be found <a href="https://wiki.archlinux.org/index.php/DeveloperWiki:Project_Leader">here</a></p> <p>In the first official vote with Levente Polyak (anthraxx), Gaetan Bisson (vesath), Giancarlo Razzolini (grazzolini), and Sven-Hendrik Haase (svenstaro) as candidates, and through 58 verified votes, a winner was chosen:</p> <p><strong>Levente Polyak (anthraxx) will be taking over the reins of this ship. Congratulations!</strong></p> <p><em>Thanks for everything over all these years,<br /> Aaron Griffin (phrakture)</em></p>Aaron GriffinMon, 24 Feb 2020 15:56:28 +0000tag:www.archlinux.org,2020-02-24:/news/the-future-of-the-arch-linux-project-leader/Planet Arch Linux migrationhttps://www.archlinux.org/news/planet-arch-linux-migration/<p>The software behind planet.archlinux.org was implemented in Python 2 and is no longer maintained upstream. This functionality has now been implemented in archlinux.org's archweb backend which is actively maintained but offers a slightly different experience.</p> <p>The most notable changes are the offered feeds and the feed location. Archweb only offers an Atom feed which is located at <a href="https://archlinux.org/feeds/planet">here</a>.</p>Jelle van der WaaSat, 22 Feb 2020 22:43:00 +0000tag:www.archlinux.org,2020-02-22:/news/planet-arch-linux-migration/sshd needs restarting after upgrading to openssh-8.2p1https://www.archlinux.org/news/sshd-needs-restarting-after-upgrading-to-openssh-82p1/<p>After upgrading to openssh-8.2p1, the existing SSH daemon will be unable to accept new connections. (See <a href="https://bugs.archlinux.org/task/65517">FS#65517</a>.) When upgrading remote hosts, please make sure to restart the SSH daemon using <code>systemctl restart sshd</code> right after running <code>pacman -Syu</code>. If you are upgrading to openssh-8.2p1-3 or higher, this restart will happen automatically.</p>Gaetan BissonMon, 17 Feb 2020 01:35:04 +0000tag:www.archlinux.org,2020-02-17:/news/sshd-needs-restarting-after-upgrading-to-openssh-82p1/rsync compatibilityhttps://www.archlinux.org/news/rsync-compatibility/<p>Our <code>rsync</code> package was shipped with bundled <code>zlib</code> to provide compatibility with the old-style <code>--compress</code> option up to version 3.1.0. Version 3.1.1 was released on 2014-06-22 and is shipped by all major distributions now.</p> <p>So we decided to finally drop the bundled library and ship a package with system <code>zlib</code>. This also fixes security issues, actual ones and in future. Go and blame those running old versions if you encounter errors with <code>rsync 3.1.3-3</code>.</p>Christian HesseWed, 15 Jan 2020 20:14:43 +0000tag:www.archlinux.org,2020-01-15:/news/rsync-compatibility/Now using Zstandard instead of xz for package compressionhttps://www.archlinux.org/news/now-using-zstandard-instead-of-xz-for-package-compression/<p>As announced on the <a href="https://lists.archlinux.org/pipermail/arch-dev-public/2019-December/029752.html">mailing list</a>, on Friday, Dec 27 2019, our package compression scheme has changed from xz (.pkg.tar.xz) to <a href="https://lists.archlinux.org/pipermail/arch-dev-public/2019-December/029778.html">zstd (.pkg.tar.zst)</a>.</p> <p>zstd and xz trade blows in their compression ratio. Recompressing all packages to zstd with our options yields a total ~0.8% increase in package size on all of our packages combined, but the decompression time for all packages saw a ~1300% speedup.</p> <p>We already have more than 545 zstd-compressed packages in our repositories, and as packages get updated more will keep rolling in. We have not found any user-facing issues as of yet, so things appear to be working.</p> <p>As a packager, you will automatically start building .pkg.tar.zst packages if you are using the latest version of devtools (&gt;= 20191227).<br /> As an end-user no manual intervention is required, assuming that you have read and followed the news post <a href="https://www.archlinux.org/news/required-update-to-recent-libarchive/">from late last year</a>.</p> <p>If you nevertheless haven't updated libarchive since 2018, all hope is not lost! Binary builds of pacman-static are available from Eli Schwartz' <a href="https://wiki.archlinux.org/index.php/Unofficial_user_repositories#eschwartz">personal repository</a> (or direct link to <a href="https://pkgbuild.com/~eschwartz/repo/x86_64-extracted/">binary</a>), signed with their Trusted User keys, with which you can perform the update.</p>Robin BrodaSat, 04 Jan 2020 20:35:55 +0000tag:www.archlinux.org,2020-01-04:/news/now-using-zstandard-instead-of-xz-for-package-compression/Xorg cleanup requires manual interventionhttps://www.archlinux.org/news/xorg-cleanup-requires-manual-intervention/<p>In the process of <a href="https://bugs.archlinux.org/task/64892">Xorg cleanup</a> the update requires manual intervention when you hit this message:</p> <pre><code>:: installing xorgproto (2019.2-2) breaks dependency 'inputproto' required by lib32-libxi :: installing xorgproto (2019.2-2) breaks dependency 'dmxproto' required by libdmx :: installing xorgproto (2019.2-2) breaks dependency 'xf86dgaproto' required by libxxf86dga :: installing xorgproto (2019.2-2) breaks dependency 'xf86miscproto' required by libxxf86misc </code></pre> <p>when updating, use: <code>pacman -Rdd libdmx libxxf86dga libxxf86misc &amp;&amp; pacman -Syu</code> to perform the upgrade.</p>Andreas RadkeFri, 20 Dec 2019 13:37:40 +0000tag:www.archlinux.org,2019-12-20:/news/xorg-cleanup-requires-manual-intervention/ ` func TestPrintNewsFeed(t *testing.T) { t.Parallel() layout := "2006-01-02" str := "2020-04-13" lastNewsTime, _ := time.Parse(layout, str) type args struct { cutOffDate time.Time sortMode int all bool quiet bool } tests := []struct { name string args args wantErr bool }{ {name: "all-verbose", args: args{cutOffDate: time.Now(), all: true, quiet: false}, wantErr: false}, {name: "all-quiet", args: args{cutOffDate: lastNewsTime, all: true, quiet: true}, wantErr: false}, {name: "latest-quiet", args: args{cutOffDate: lastNewsTime, all: false, quiet: true}, wantErr: false}, {name: "latest-quiet-topdown", args: args{sortMode: 1, cutOffDate: lastNewsTime, all: false, quiet: true}, wantErr: false}, } for _, tt := range tests { tt := tt t.Run(tt.name, func(t *testing.T) { gock.New("https://archlinux.org"). Get("/feeds/news"). Reply(200). BodyString(sampleNews) defer gock.Off() rescueStdout := os.Stdout r, w, _ := os.Pipe() os.Stdout = w err := PrintNewsFeed(context.TODO(), &http.Client{}, tt.args.cutOffDate, tt.args.sortMode, tt.args.all, tt.args.quiet) assert.NoError(t, err) w.Close() out, _ := ioutil.ReadAll(r) cupaloy.SnapshotT(t, out) os.Stdout = rescueStdout }) } }