[Openstack-operators] [ops][tags][packaging] ops:packaging tag - a little common sense, please
Jay Pipes
jaypipes at gmail.com
Wed Jun 10 17:51:19 UTC 2015
Cross-posting to -operators and -dev because this involves *packagers*
of OpenStack, as well as operators who use those packages.
Hello Operators,
First, let me start out by saying if you were offended by my snarky
comments at yesterday's TC meeting [1] regarding the direction of the
Ops Tags Team, I apologize. Sometimes I am snarky and/or moody,
especially when I feel strongly about something, as is the case here.
Please accept my apologies. Let's move on.
= tl;dr =
* The proposed things are not tags
* Operators should not be curating packaging tags (packagers should)
* Tags should not have a "value" component
* Packaging tags should be release-specific, or they will be wrong
= The details =
OK, that said, here are the issues I have with the proposed
ops:packaging tags [2].
= The proposed things are not "tags" =
The things being proposed by the Ops Tags Team are in fact not "tags",
which are simple strings of binary information that have a well-defined
and singular meaning.
What the Ops Tags Team has proposed is structured, schema-full data
objects. There is nothing wrong with having a structured object for
purposes of generating useful information. But please don't call these
things "tags", because they aren't.
Before I move on to other issues, I'd like to point out that the more
you go down the route of adding more and more attributes, most of which
would be optional, to these structured documents, the more you will run
into a problem of having stale and misleading data contained in these
JSON files. And that will lead to a worse user experience for operators
than the current wiki, which, like all wikis, is notoriously out-of-date
in many places.
A tag should mean one thing, and one thing only, to encourage clarity.
The definition of the tag should be decisive regarding why a particular
project has been tagged with that tag.
= Operators should not be curating packaging tags =
*Packagers* should be curating tags that correspond to whether or not
packages exist for particular projects in OpenStack. Operators consume
these packages, for sure, but the packagers in the upstream operating
system communities are the ones that know the most accurate information
about the state of packaging for a particular project and a particular
release.
I strongly believe that these ops:packaged tags should really just be
tags in the openstack/governance repository (i.e. regular TC tags) and
be curated by the packaging community, which means they would not have
the "ops:" prefix on them.
= Remove "value" component from the "tag" =
The current proposal for both ops:packaged and ops:production-use [3]
tag definitions include a "value" component. For example, the
ops:packaged tags must include one of the following "values":
- good
- beginning
- warning
- no
With each of the above values attempting to indicate to the audience
that the packages for a particular project are in varying states of
repair and "bug-freeness". There are a number of problems with including
this "value" in the tag:
1) This value judgement about the packaging quality is ripe for getting
out-of-date VERY quickly. Who is going to continually update the value
parts for the different projects? Things change very quickly in
packaging-land. Bugs are fixed, new packages built and published. Who in
the ops community is going to track this? Please see point above about
"Operators should not be curating packaging tags".
2) All software, including packages, has bugs. This is something that
the Ops community just needs to accept and get over. Quabbling with each
other about what constitutes a "major" bug in packaging and how many
"major" bugs bugs constitute a "warning" value is less than useful to
the audience here. Instead, the ops community should focus on providing
useful documentation and links to the audience, in the form of long-form
release notes or opinions about packages and documentation on the
OpenStack wiki.
= Packaging tags should be release-specific, or they will be wrong =
For these packaging tags, the release must be part of the tag itself,
otherwise the information it denotes would be indeterminate.
As an example, suppose you have a tag that looks like this:
ops:packaged:centos:good
And in the tag definition you say that the tag is applied to projects
that have CentOS RPM packages available "within the last 6 months".
Well, as you all know, packages are published for a *particular release
of OpenStack*. So, if Nova is tagged with ops:packaged:centos:good in,
say, August 2015, the tag would ostensibly be saying that packages exist
for Nova in Kilo. However, once November rolls around, and packages for
Liberty don't (yet) exist, are you going to remove this
"ops:packaged:centos:good" tag from Nova or (worse) change it to
"ops:pacakged:centos:no"?
Instead, have the tag be specific to a release of OpenStack:
packaged:centos:kilo
= In summary =
In short, I would love it if the Ops Tags team would stick with binary
tag definitions -- a tag should mean one thing and one thing only.
I don't believe the Ops Tags team should be curating the packaging tags
-- the packaging community should do that, and do that under the main
openstack/governance repository.
Packagers, I would love it if you would curate a set of tags that looks
kind of like this:
- packaged:centos:kilo
- packaged:ubuntu:liberty
- packaged:sles:juno
I will be proposing the above tag definition to the openstack/governance
repository this week.
Thanks for listening,
-jay
[1]
http://eavesdrop.openstack.org/irclogs/%23openstack-meeting/%23openstack-meeting.2015-06-09.log.html#t2015-06-09T20:18:00
[2] https://review.openstack.org/#/c/186633
[3] https://review.openstack.org/#/c/189168
More information about the OpenStack-operators
mailing list