Hi! 

On Thu, 09 Jul 2015, Steev Klimaszewski wrote:
> On Wed, 2015-07-08 at 21:11 +0200, Tobias Klausmann wrote:
> > The truly arch-dependent bugs are what wastes my time:
> > 
> > For example:
> > 
> > - dependencies not being keyworded for arch or ~arch but only
> >   amd64/~amd64
> > - dependencies not even building on ~arch, but on ~amd64
> > - package assuming availability of gcc/ghc/Python-X.Y when
> >   arch/~arch only has something for <Y or <X
> > - my favourite: assuming udev is at version X for arch/~arch when
> >   it has been broken there for roughly twelve kernel versions due
> >   to udev/systemd upstream not caring. The information is one
> >   equery-y command line away, but no, let's file that bug.
> 
> That's a failing of the arch team or the committer then - or whomever
> keyworded the package without testing the dependencies.  That's why the
> keywording bugs happen when dependencies change - and yes, occasionally
> a dependency loses it's keywords and that may be where the issue comes
> from, I'm not sure.  This used to be watched very closely, but I believe
> the tool being used broke at some point.
> 
> What exactly do you mean, it's just one command line away but let's file
> the bug - yes a bug SHOULD be filed, so that the people know of the
> issue so it doesn't get repeated, over and over.  

What I meant is when I get a stabilization bug for
cat-egory/foo-1.2.3 which depends on >=other-cat/bar-1.0.5. The
latter is amd64 but not alpha or ~alpha. And it, in turn, has yet
more deps in the same vein. Now I have several options:

1/ Pull in all dependencies and test them. This may mean I have
   to let the deps soak in ~alpha for 30 days, leading the
   original dev to complain that the arches are slow.
2/ Try and figure out if I can mask a USE flag on foo-1.2.3 that
   avoids the dependency. If there isn't I can try and make one,
   which leads into another hell of dep chasing for revdeps of
   foo-1.2.3.
3/ Complain on the bug that the maintainer of foo-1.2.3 should
   figure out the deptrees before CCing arches.
4/ Opt out of stabilization for foo-1.2.3

If it turns out that bar-1.0.5 or one of its deps breaks a
completely unrelated package, I get to revert all of this until a
fix is found. And then do it all over again.

What instead should happen:

The maintainer of cat-egory/foo sees that 1.2.3 has a new dep,
which is >=other-cat/bar-1.0.5. A quick check with equery* shows
that it isn't stable/keyworded for alpha and hppa.

Thus, the maintainer files a bug for bar-1.0.5 to be stable on
alpha and hppa, possibly/ideally checking with bar's maintainer.
The stabilization for foo-1.2.3 on amd64 can continue, just don't
CC alpha and hppa yet.

Once bar-1.0.5 is stable (or alpha/hppa have opted out), CC them
on the foo-1.2.3 bug.

*(An alternative is to add all the keywords you want and run
  repoman full. Just don't accidentally commit that edit.)

The bad case (ignoring the non-amd64 deptree) is not the
majority, but it's a very frustrating and time consuming
experience for archtesters. Often, the deptrees for the minor
archs are broken in subtly different ways, resulting in the time
wasting to be multiplied.

Option #3 above I have shied away from, since it would feel sort
of aggressive, pedantic and picky when that is not really in my
nature. If everyone is okay(ish) with it, I'll start doing it.

> > Having every arch team chase the deps for every package is very,
> > very frustrating, since it is so trivial a problem. We need a
> > tool that answers the question: "I want to mov cat/pkg-1.2.3 to
> > stable for arches a, b and c, what do I need?" for _every
> > package_. Some groups seem to have tooling for this, but it is
> > far from easily (obviously?) available, so every team gets to
> > re-discover dependency hell. Ruby is especially bad since
> > FEATURES=test make the depgraph explode (and sometimes circular).
> 
> The only fear I have about CI, is that we turn into every other distro
> out there where "it builds, ship it!" - I know I prefer to have our arm
> team actually test the packages more than just doing FEATURES=test
> (assuming the tests aren't broken on arm) emerge, although I know there
> are some people on the team who feel that it's too much to actually test
> all of the arm boards. For a long time, certain binary distros were
> compiling anything and everything, and if it built for other arches it
> was available.  Even if there was no way it would possibly work on that
> arch.  

We're already partway down that road of IC,SI. For Alpha, it's
not because we don't want to, but rather because we know that if
we do it 100% properly, we will quickly fall even further behind.
I guess we do speculative testing: If it compiles+tests, great.
If the package actually breaks, a user will surely tell us.


Yes, CI is nice to have if you have the hardware to do it. But if
parts of our workflow start depending on it, we will quickly lose
the minor archs.

Regards,
Tobias

-- 
prom_printf("No VAC. Get some bucks and buy a real computer.");
        linux-2.6.19/arch/sparc/mm/sun4c.c

Reply via email to