mirror of
				https://github.com/SmartHoneybee/ubiquitous-memory
				synced 2025-10-25 07:43:49 +02:00 
			
		
		
		
	Compare commits
	
		
			28 Commits
		
	
	
		
			untagged-a
			...
			untagged-4
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 4f58e13ed1 | ||
|  | 205431da5a | ||
|  | 62ff5c6c21 | ||
|  | c602d86ba3 | ||
|  | f95c324df8 | ||
|  | 27211d5341 | ||
|  | 04a80b8c61 | ||
|  | cce9a5e9f6 | ||
|  | 4338daa488 | ||
|  | adfadb5db1 | ||
|  | 9ec2d52a6f | ||
|  | 73a0247466 | ||
|  | 8e48ad9fd6 | ||
|  | 9fbbcc9efa | ||
|  | a841d22ea1 | ||
|  | 53a8823dd3 | ||
|  | 2b81bf9c79 | ||
|  | 656fcc3022 | ||
|  | 64b4df143a | ||
|  | 6245638306 | ||
|  | f00ec524e3 | ||
|  | 5a5da5e379 | ||
|  | f041990920 | ||
|  | c5d346a10a | ||
|  | a46b0240e4 | ||
|  | 767566cb74 | ||
|  | cdb30c1b6a | ||
|  | 762155e2bd | 
							
								
								
									
										99
									
								
								.travis.yml
									
									
									
									
									
								
							
							
						
						
									
										99
									
								
								.travis.yml
									
									
									
									
									
								
							| @@ -1,54 +1,69 @@ | ||||
| language: c | ||||
| dist: trusty | ||||
| addons: | ||||
|   apt: | ||||
|     sources: | ||||
|       - sourceline: 'deb https://dl.yarnpkg.com/debian/ stable main' | ||||
|         key_url: 'https://dl.yarnpkg.com/debian/pubkey.gpg' | ||||
|       - sourceline: 'deb https://deb.nodesource.com/node_8.x trusty main' | ||||
|         key_url: 'https://deb.nodesource.com/gpgkey/nodesource.gpg.key' | ||||
|     packages: | ||||
|       - nodejs | ||||
|       - yarn | ||||
|       - build-essential | ||||
| sudo: required | ||||
| service: | ||||
|   - docker | ||||
| env: | ||||
|   global: | ||||
|     - GOV=1.9 | ||||
|     - GOPATH=$HOME/go | ||||
|     - GOROOT=$HOME/$GOV/go | ||||
|     - PATH=$GOROOT/bin:$PATH:$GOPATH/bin | ||||
|     - APT_KEY_NODEJS='9FD3B784BC1C6FC31A8A0A1C1655A0AB68576280' | ||||
|     - DEBIAN_RELEASE='stretch' | ||||
|     - DOCKER_BUILD_USER='build-user' | ||||
|     - DOCKER_PWD='/root' | ||||
|     - DOCKER_IMAGE="debian:${DEBIAN_RELEASE}" | ||||
|     - GOPATH='${HOME}/go' | ||||
|     - SRCROOT="${GOPATH}/src/github.com/mattermost"     | ||||
|   matrix: | ||||
|     - V=4.4.0 | ||||
|     - V=5.4.0 | ||||
| before_install: | ||||
|   - install -d $GOPATH $GOROOT | ||||
|   - wget https://storage.googleapis.com/golang/go$GOV.linux-amd64.tar.gz | ||||
|   - tar -C $HOME/$GOV -xzf go$GOV.linux-amd64.tar.gz | ||||
|   - node --version | ||||
|   - yarn versions | ||||
|   - go version | ||||
|   - ulimit -n 8096 | ||||
|   - install -d ~/go/src/github.com/mattermost | ||||
|   - cd ~/go/src/github.com/mattermost | ||||
|   - wget "https://github.com/mattermost/mattermost-server/archive/v${V}.tar.gz" | ||||
|   - tar xf "v${V}.tar.gz" | ||||
|   - mv "mattermost-server-${V}" mattermost-server | ||||
|   - rm "v${V}.tar.gz" | ||||
|   - wget "https://github.com/mattermost/mattermost-webapp/archive/v${V}.tar.gz" | ||||
|   - tar xf "v${V}.tar.gz" | ||||
|   - mv "mattermost-webapp-${V}" mattermost-webapp | ||||
|   - rm "v${V}.tar.gz" | ||||
|   - l() { echo "${@}" >> setup.sh; } | ||||
|   - l '#!/bin/bash' | ||||
|   - l set -ex | ||||
|   # setup build environment as root | ||||
|   - l 'if [ ${UID} -eq 0 ]; then' | ||||
|   - l useradd -md "${DOCKER_PWD}/${DOCKER_BUILD_USER}" "${DOCKER_BUILD_USER}" | ||||
|   - l echo 'APT::Install-Recommends "0"\; APT::Install-Suggests "0"\;' '>' /etc/apt/apt.conf.d/99reduce-it | ||||
|   - l apt-get update | ||||
|   - l apt-get install -yq gnupg2 dirmngr apt-transport-https ca-certificates | ||||
|   - l apt-key adv --keyserver keyserver.ubuntu.com --recv-keys "${APT_KEY_NODEJS}" | ||||
|   - l echo "deb http://deb.debian.org/debian ${DEBIAN_RELEASE}-backports main" '>' /etc/apt/sources.list.d/backports.list | ||||
|   - l echo "deb-src http://deb.debian.org/debian ${DEBIAN_RELEASE} main" '>' /etc/apt/sources.list.d/stable-source.list | ||||
|   - l echo "deb https://deb.nodesource.com/node_10.x ${DEBIAN_RELEASE} main" '>' /etc/apt/sources.list.d/bad-node.list | ||||
|   - l apt-get update | ||||
|   - l apt-get install -yqt "${DEBIAN_RELEASE}-backports" golang-go | ||||
|   - l apt-get install -yq wget build-essential patch git nodejs | ||||
|   - l apt-get build-dep -yq pngquant | ||||
|   - l install -d -o "${DOCKER_BUILD_USER}" '"$(go env GOROOT)/pkg/linux_arm"' | ||||
|   - l cp --verbose '"${0}"' "${DOCKER_PWD}/${DOCKER_BUILD_USER}" | ||||
|   # switch to non-root user | ||||
|   - l exec su --shell /bin/bash --login "${DOCKER_BUILD_USER}" '"${0}"' '"${@}"' | ||||
|   - l 'fi' | ||||
|   # build as non-root user | ||||
|   - l install -d "${SRCROOT}/mattermost-{server,webapp}" "${GOPATH}/bin" | ||||
|   - l npm install yarn | ||||
|   - l wget -q "https://github.com/mattermost/mattermost-server/archive/v${V}.tar.gz" -O mattermost-server.tar.gz | ||||
|   - l tar -C "${SRCROOT}/mattermost-server" --strip-components=1 -xf mattermost-server.tar.gz | ||||
|   - l wget -q "https://github.com/mattermost/mattermost-webapp/archive/v${V}.tar.gz" -O mattermost-webapp.tar.gz | ||||
|   - l tar -C "${SRCROOT}/mattermost-webapp" --strip-components=1 -xf mattermost-webapp.tar.gz | ||||
|   - l make build -C "${SRCROOT}/mattermost-webapp" | ||||
|   # workaround (instead of patch): platform binary is in GOOS_GOARCH, Makefile expects it in linux_amd64 | ||||
|   - l ln -s "${GOPATH}/bin/linux_arm" "${GOPATH}/bin/linux_amd64" | ||||
|   # adapt and revert reverted commit, https://github.com/mattermost/mattermost-server/pull/8537 | ||||
|   - l patch -d "${SRCROOT}/mattermost-server" -p1 '<' "${DOCKER_PWD}/build-release.patch" | ||||
|   # workaround (instead of patch): overwrite GO variable to enforce desired GOARCH | ||||
|   - l export GOPATH="${GOPATH}" GOARM=7 | ||||
|   - l make config-reset build-linux package-linux -C "${SRCROOT}/mattermost-server" PLUGIN_PACKAGES="" GO='"GOARCH=arm $(which go)"' BUILD_NUMBER="dev-arm-tag${V}" | ||||
|   # workaround (instead of patch): Makefile creates *-amd64.tar.gz | ||||
|   - l mv "${SRCROOT}/mattermost-server/dist/mattermost-team-linux-amd64.tar.gz" "${DOCKER_PWD}/${DOCKER_BUILD_USER}/mattermost-${V}-arm.tar.gz" | ||||
|   - l sha512sum "${DOCKER_PWD}/${DOCKER_BUILD_USER}/mattermost-${V}-arm.tar.gz" '|' tee "${DOCKER_PWD}/${DOCKER_BUILD_USER}/mattermost-${V}-arm.tar.gz.sha512sum" | ||||
|   - docker pull "${DOCKER_IMAGE}" | ||||
|   - chmod +x setup.sh | ||||
| script: | ||||
|   - make build -C ~/go/src/github.com/mattermost/mattermost-webapp | ||||
|   - cd ~/go/src/github.com/mattermost/mattermost-server | ||||
|   - patch -p1 < $TRAVIS_BUILD_DIR/make.patch | ||||
|   - go get -d ./... | ||||
|   - make build-linux package BUILD_NUMBER="dev-arm-tag${V}" | ||||
|   - mv -v ~/go/src/github.com/mattermost/mattermost-server/dist/mattermost-*-linux-arm.tar.gz $TRAVIS_BUILD_DIR/mattermost-$V-arm.tar.gz | ||||
|   - sha512sum $TRAVIS_BUILD_DIR/mattermost-$V-arm.tar.gz | tee $TRAVIS_BUILD_DIR/mattermost-$V-arm.tar.gz.sha512sum | ||||
|   - docker run --interactive=true --mount="type=bind,source=${PWD},destination=${DOCKER_PWD}" --rm=true --tty=true --workdir="${DOCKER_PWD}" "${DOCKER_IMAGE}" ./setup.sh | ||||
| deploy: | ||||
|   provider: releases | ||||
|   api_key: "${GITHUB_OAUTH_TOKEN}" | ||||
|   file: | ||||
|     - "$TRAVIS_BUILD_DIR/mattermost-$V-arm.tar.gz" | ||||
|     - "$TRAVIS_BUILD_DIR/mattermost-$V-arm.tar.gz.sha512sum" | ||||
|     - "${TRAVIS_BUILD_DIR}/${DOCKER_BUILD_USER}/setup.sh" | ||||
|     - "${TRAVIS_BUILD_DIR}/${DOCKER_BUILD_USER}/mattermost-${V}-arm.tar.gz" | ||||
|     - "${TRAVIS_BUILD_DIR}/${DOCKER_BUILD_USER}/mattermost-${V}-arm.tar.gz.sha512sum" | ||||
|   skip_cleanup: true | ||||
|   | ||||
							
								
								
									
										11
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								README.md
									
									
									
									
									
								
							| @@ -1 +1,10 @@ | ||||
| # ubiquitous-memory | ||||
| # ubiquitous-memory: [Here be dragons][3] | ||||
|  | ||||
| [](https://travis-ci.org/SmartHoneybee/ubiquitous-memory) | ||||
|  | ||||
| [Travis CI][0] recipe that builds [Mattermost][1] for Linux on [ARMv7][2]-compatible devices. | ||||
|  | ||||
| [0]: https://travis-ci.org/SmartHoneybee/ubiquitous-memory | ||||
| [1]: https://mattermost.com/ | ||||
| [2]: https://github.com/golang/go/wiki/GoArm#supported-architectures | ||||
| [3]: https://en.wikipedia.org/wiki/Here_be_dragons | ||||
|   | ||||
							
								
								
									
										33
									
								
								build-release.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								build-release.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | ||||
| From 556e16211ed1b4c146ca2a094688618458182ae7 Mon Sep 17 00:00:00 2001 | ||||
| From: Your Name <you@example.com> | ||||
| Date: Wed, 6 Jun 2018 12:34:56 +0100 | ||||
| Subject: [PATCH] Split make goal | ||||
|  | ||||
| --- | ||||
|  build/release.mk | 4 ++-- | ||||
|  1 file changed, 2 insertions(+), 2 deletions(-) | ||||
|  | ||||
| diff --git a/build/release.mk b/build/release.mk | ||||
| index 238343e..1b7859f 100644 | ||||
| --- a/build/release.mk | ||||
| +++ b/build/release.mk | ||||
| @@ -61,7 +61,7 @@ endif | ||||
|  	cp README.md $(DIST_PATH) | ||||
|   | ||||
|  	@# ----- PLATFORM SPECIFIC ----- | ||||
| - | ||||
| +_: | ||||
|  	@# Make osx package | ||||
|  	@# Copy binary | ||||
|  ifeq ($(BUILDER_GOOS_GOARCH),"darwin_amd64") | ||||
| @@ -106,7 +106,7 @@ endif | ||||
|  	rm -f $(DIST_PATH)/bin/mattermost.exe | ||||
|  	rm -f $(DIST_PATH)/bin/platform.exe | ||||
|  	rm -f $(DIST_PATH)/prepackaged_plugins/* | ||||
| - | ||||
| +package-linux: package | ||||
|  	@# Make linux package | ||||
|  	@# Copy binary | ||||
|  ifeq ($(BUILDER_GOOS_GOARCH),"linux_amd64") | ||||
| --  | ||||
| 2.11.0 | ||||
							
								
								
									
										63
									
								
								make.patch
									
									
									
									
									
								
							
							
						
						
									
										63
									
								
								make.patch
									
									
									
									
									
								
							| @@ -1,63 +0,0 @@ | ||||
| diff --git a/build/release.mk b/build/release.mk | ||||
| index 5eaee80..e0e13bf 100644 | ||||
| --- a/build/release.mk | ||||
| +++ b/build/release.mk | ||||
| @@ -3,7 +3,7 @@ dist: | check-style test package | ||||
|   | ||||
|  build-linux: | ||||
|  	@echo Build Linux amd64 | ||||
| -	env GOOS=linux GOARCH=amd64 $(GO) install $(GOFLAGS) $(GO_LINKER_FLAGS) ./cmd/platform | ||||
| +	env GOOS=linux GOARCH=arm $(GO) install $(GOFLAGS) $(GO_LINKER_FLAGS) ./cmd/platform | ||||
|   | ||||
|  build-osx:  | ||||
|  	@echo Build OSX amd64 | ||||
| @@ -32,6 +32,7 @@ package: | ||||
|   | ||||
|  	@# Resource directories | ||||
|  	cp -RL config $(DIST_PATH) | ||||
| +	mv $(DIST_PATH)/config/default.json $(DIST_PATH)/config/config.json | ||||
|  	cp -RL fonts $(DIST_PATH) | ||||
|  	cp -RL templates $(DIST_PATH) | ||||
|  	cp -RL i18n $(DIST_PATH) | ||||
| @@ -61,38 +62,14 @@ endif | ||||
|   | ||||
|  	@# ----- PLATFORM SPECIFIC ----- | ||||
|   | ||||
| -	@# Make osx package | ||||
| -	@# Copy binary | ||||
| -ifeq ($(BUILDER_GOOS_GOARCH),"darwin_amd64") | ||||
| -	cp $(GOPATH)/bin/platform $(DIST_PATH)/bin # from native bin dir, not cross-compiled | ||||
| -else | ||||
| -	cp $(GOPATH)/bin/darwin_amd64/platform $(DIST_PATH)/bin # from cross-compiled bin dir | ||||
| -endif | ||||
| -	@# Package | ||||
| -	tar -C dist -czf $(DIST_PATH)-$(BUILD_TYPE_NAME)-osx-amd64.tar.gz mattermost | ||||
| -	@# Cleanup | ||||
| -	rm -f $(DIST_PATH)/bin/platform | ||||
| - | ||||
| -	@# Make windows package | ||||
| -	@# Copy binary | ||||
| -ifeq ($(BUILDER_GOOS_GOARCH),"windows_amd64") | ||||
| -	cp $(GOPATH)/bin/platform.exe $(DIST_PATH)/bin # from native bin dir, not cross-compiled | ||||
| -else | ||||
| -	cp $(GOPATH)/bin/windows_amd64/platform.exe $(DIST_PATH)/bin # from cross-compiled bin dir | ||||
| -endif | ||||
| -	@# Package | ||||
| -	cd $(DIST_ROOT) && zip -9 -r -q -l mattermost-$(BUILD_TYPE_NAME)-windows-amd64.zip mattermost && cd .. | ||||
| -	@# Cleanup | ||||
| -	rm -f $(DIST_PATH)/bin/platform.exe | ||||
| - | ||||
|  	@# Make linux package | ||||
|  	@# Copy binary | ||||
| -ifeq ($(BUILDER_GOOS_GOARCH),"linux_amd64") | ||||
| +ifeq ($(BUILDER_GOOS_GOARCH),"linux_arm") | ||||
|  	cp $(GOPATH)/bin/platform $(DIST_PATH)/bin # from native bin dir, not cross-compiled | ||||
|  else | ||||
| -	cp $(GOPATH)/bin/linux_amd64/platform $(DIST_PATH)/bin # from cross-compiled bin dir | ||||
| +	cp $(GOPATH)/bin/linux_arm/platform $(DIST_PATH)/bin # from cross-compiled bin dir | ||||
|  endif | ||||
|  	@# Package | ||||
| -	tar -C dist -czf $(DIST_PATH)-$(BUILD_TYPE_NAME)-linux-amd64.tar.gz mattermost | ||||
| +	tar -C dist -czf $(DIST_PATH)-$(BUILD_TYPE_NAME)-linux-arm.tar.gz mattermost | ||||
|  	@# Don't clean up native package so dev machines will have an unzipped package available | ||||
|  	@#rm -f $(DIST_PATH)/bin/platform | ||||
		Reference in New Issue
	
	Block a user