[Mesa-dev] [PATCH] travis: Initial import of travis instructions.
Matt Turner
mattst88 at gmail.com
Tue Nov 24 11:19:41 PST 2015
On Tue, Nov 24, 2015 at 11:13 AM, Rob Clark <robdclark at gmail.com> wrote:
> On Tue, Nov 24, 2015 at 2:10 PM, Ilia Mirkin <imirkin at alum.mit.edu> wrote:
>> On Tue, Nov 24, 2015 at 2:04 PM, Eric Anholt <eric at anholt.net> wrote:
>>> This just builds/installs our dependencies, and runs "make check". I'm
>>> interested in integrating more tests into it, but this seems like a pretty
>>> easy first start.
>>>
>>> If your personal branches of Mesa are on github, you can enable it on your
>>> account and the repository (see
>>> https://docs.travis-ci.com/user/for-beginners), then any pushes you do
>>> will get their HEAD commit tested, and any pull requests to your tree will
>>> get their merge commits tested.
>>> ---
>>>
>>> I'd really like to have *some* sort of publicly available CI for
>>> people hacking on Mesa. We've all seen how many times make check has
>>> been broken, so this was an easy start. Travis doesn't seem optimal,
>>> since it doesn't test each commit, but I think it's better than
>>> nothing, and the cost is this little file and bumping the versions of
>>> dependencies to download when we update configure.ac requirements.
>>>
>>> .travis.yml | 92 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
>>> 1 file changed, 92 insertions(+)
>>> create mode 100644 .travis.yml
>>>
>>> diff --git a/.travis.yml b/.travis.yml
>>> new file mode 100644
>>> index 0000000..31cd5c2
>>> --- /dev/null
>>> +++ b/.travis.yml
>>> @@ -0,0 +1,92 @@
>>> +language: c
>>> +
>>> +sudo: false
>>> +
>>> +cache:
>>> + directories:
>>> + - $HOME/.ccache
>>> +
>>> +addons:
>>> + apt:
>>> + packages:
>>> + - libdrm-dev
>>> + - libudev-dev
>>> + - x11proto-xf86vidmode-dev
>>> + - libexpat1-dev
>>> + - libxcb-dri2-0-dev
>>> + - libx11-xcb-dev
>>> + - llvm-3.4-dev
>>> +
>>> +env:
>>> + global:
>>> + - XORG_RELEASES=http://xorg.freedesktop.org/releases/individual
>>> + - XCB_RELEASES=http://xcb.freedesktop.org/dist
>>> + - XORGMACROS_VERSION=util-macros-1.19.0
>>> + - GLPROTO_VERSION=glproto-1.4.17
>>> + - DRI2PROTO_VERSION=dri2proto-2.8
>>> + - DRI3PROTO_VERSION=dri3proto-1.0
>>> + - PRESENTPROTO_VERSION=presentproto-1.0
>>> + - LIBPCIACCESS_VERSION=libpciaccess-0.13.4
>>> + - LIBDRM_VERSION=libdrm-2.4.65
>>> + - XCBPROTO_VERSION=xcb-proto-1.11
>>> + - LIBXCB_VERSION=libxcb-1.11
>>> + - LIBXSHMFENCE_VERSION=libxshmfence-1.2
>>> + - PKG_CONFIG_PATH=$HOME/prefix/lib/pkgconfig
>>> +
>>> +install:
>>> + - export PATH="/usr/lib/ccache:$PATH"
>>> + - pip install --user mako
>>> +
>>> + # Install dependencies where we require specific versions (or where
>>> + # disallowed by Travis CI's package whitelisting).
>>> +
>>> + - wget $XORG_RELEASES/util/$XORGMACROS_VERSION.tar.bz2
>>> + - tar -jxvf $XORGMACROS_VERSION.tar.bz2
>>> + - (cd $XORGMACROS_VERSION && ./configure --prefix=$HOME/prefix && make install)
>>> +
>>> + - wget $XORG_RELEASES/proto/$GLPROTO_VERSION.tar.bz2
>>> + - tar -jxvf $GLPROTO_VERSION.tar.bz2
>>> + - (cd $GLPROTO_VERSION && ./configure --prefix=$HOME/prefix && make install)
>>> +
>>> + - wget $XORG_RELEASES/proto/$DRI2PROTO_VERSION.tar.bz2
>>> + - tar -jxvf $DRI2PROTO_VERSION.tar.bz2
>>> + - (cd $DRI2PROTO_VERSION && ./configure --prefix=$HOME/prefix && make install)
>>> +
>>> + - wget $XORG_RELEASES/proto/$DRI3PROTO_VERSION.tar.bz2
>>> + - tar -jxvf $DRI3PROTO_VERSION.tar.bz2
>>> + - (cd $DRI3PROTO_VERSION && ./configure --prefix=$HOME/prefix && make install)
>>> +
>>> + - wget $XORG_RELEASES/proto/$PRESENTPROTO_VERSION.tar.bz2
>>> + - tar -jxvf $PRESENTPROTO_VERSION.tar.bz2
>>> + - (cd $PRESENTPROTO_VERSION && ./configure --prefix=$HOME/prefix && make install)
>>> +
>>> + - wget $XCB_RELEASES/$XCBPROTO_VERSION.tar.bz2
>>> + - tar -jxvf $XCBPROTO_VERSION.tar.bz2
>>> + - (cd $XCBPROTO_VERSION && ./configure --prefix=$HOME/prefix && make install)
>>> +
>>> + - wget $XCB_RELEASES/$LIBXCB_VERSION.tar.bz2
>>> + - tar -jxvf $LIBXCB_VERSION.tar.bz2
>>> + - (cd $LIBXCB_VERSION && ./configure --prefix=$HOME/prefix && make install)
>>> +
>>> + - wget $XORG_RELEASES/lib/$LIBPCIACCESS_VERSION.tar.bz2
>>> + - tar -jxvf $LIBPCIACCESS_VERSION.tar.bz2
>>> + - (cd $LIBPCIACCESS_VERSION && ./configure --prefix=$HOME/prefix && make install)
>>> +
>>> + - wget http://dri.freedesktop.org/libdrm/$LIBDRM_VERSION.tar.bz2
>>> + - tar -jxvf $LIBDRM_VERSION.tar.bz2
>>> + - (cd $LIBDRM_VERSION && ./configure --prefix=$HOME/prefix && make install)
>>> +
>>> + - wget $XORG_RELEASES/lib/$LIBXSHMFENCE_VERSION.tar.bz2
>>> + - tar -jxvf $LIBXSHMFENCE_VERSION.tar.bz2
>>> + - (cd $LIBXSHMFENCE_VERSION && ./configure --prefix=$HOME/prefix && make install)
>>> +
>>> +# Disabled LLVM (and therefore r300 and r600) because the build fails
>>> +# with "undefined reference to `clock_gettime'" and "undefined
>>> +# reference to `setupterm'" in llvmpipe.
>>> +script:
>>> + - ./autogen.sh --enable-debug
>>> + --disable-gallium-llvm
>>> + --with-egl-platforms=x11,drm
>>> + --with-dri-drivers=i915,i965,radeon,r200,swrast,nouveau
>>> + --with-gallium-drivers=svga,swrast,vc4,virgl
>>
>> Any reason not to add freedreno and nouveau in here?
>>
>> Too bad these packages don't all have "latest" symlinks...
>
> hmm, I was going to say that tinderbox can figure out how to just
> build latest (plus we at one point had builders for several different
> arch's for xserver and mesa, etc..)
>
> but then I noticed that http://tinderbox.x.org/ is in kind of dire shape.. :-(
Is it?
http://tinderbox.x.org/builds/2015-11-24-0009/
It looks like xf86-video-v4l and -wsfb are failing, and that's it.
More information about the mesa-dev
mailing list