##// END OF EJS Templates
nix: don't allow overriding the import packages. This causes overlays to fail
marcink -
r3189:ed6bb022 default
parent child Browse files
Show More
@@ -1,294 +1,294 b''
1 # Nix environment for the community edition
1 # Nix environment for the community edition
2 #
2 #
3 # This shall be as lean as possible, just producing the enterprise-ce
3 # This shall be as lean as possible, just producing the enterprise-ce
4 # derivation. For advanced tweaks to pimp up the development environment we use
4 # derivation. For advanced tweaks to pimp up the development environment we use
5 # "shell.nix" so that it does not have to clutter this file.
5 # "shell.nix" so that it does not have to clutter this file.
6 #
6 #
7 # Configuration, set values in "~/.nixpkgs/config.nix".
7 # Configuration, set values in "~/.nixpkgs/config.nix".
8 # example
8 # example
9 # {
9 # {
10 # # Thoughts on how to configure the dev environment
10 # # Thoughts on how to configure the dev environment
11 # rc = {
11 # rc = {
12 # codeInternalUrl = "https://usr:token@internal-code.rhodecode.com";
12 # codeInternalUrl = "https://usr:token@code.rhodecode.com/internal";
13 # sources = {
13 # sources = {
14 # rhodecode-vcsserver = "/home/user/work/rhodecode-vcsserver";
14 # rhodecode-vcsserver = "/home/user/work/rhodecode-vcsserver";
15 # rhodecode-enterprise-ce = "/home/user/work/rhodecode-enterprise-ce";
15 # rhodecode-enterprise-ce = "/home/user/work/rhodecode-enterprise-ce";
16 # rhodecode-enterprise-ee = "/home/user/work/rhodecode-enterprise-ee";
16 # rhodecode-enterprise-ee = "/home/user/work/rhodecode-enterprise-ee";
17 # };
17 # };
18 # };
18 # };
19 # }
19 # }
20
20
21 args@
21 args@
22 { pythonPackages ? "python27Packages"
22 { pythonPackages ? "python27Packages"
23 , pythonExternalOverrides ? self: super: {}
23 , pythonExternalOverrides ? self: super: {}
24 , doCheck ? false
24 , doCheck ? false
25 , ...
25 , ...
26 }:
26 }:
27 let pkgs_ = (import <nixpkgs> {}); in
28
27
29 let
28 let
30 # Use nixpkgs from args or import them. We use this indirect approach
29 pkgs_ = (import <nixpkgs> {});
31 # through args to be able to use the name `pkgs` for our customized packages.
30 in
32 # Otherwise we will end up with an infinite recursion.
31
33 pkgs = args.pkgs or (import <nixpkgs> {
32 let
33 pkgs = import <nixpkgs> {
34 overlays = [
34 overlays = [
35 (import ./pkgs/overlays.nix)
35 (import ./pkgs/overlays.nix)
36 ];
36 ];
37 inherit
37 inherit
38 (pkgs_)
38 (pkgs_)
39 system;
39 system;
40 });
40 };
41
41
42 # Works with the new python-packages, still can fallback to the old
42 # Works with the new python-packages, still can fallback to the old
43 # variant.
43 # variant.
44 basePythonPackagesUnfix = basePythonPackages.__unfix__ or (
44 basePythonPackagesUnfix = basePythonPackages.__unfix__ or (
45 self: basePythonPackages.override (a: { inherit self; }));
45 self: basePythonPackages.override (a: { inherit self; }));
46
46
47 # Evaluates to the last segment of a file system path.
47 # Evaluates to the last segment of a file system path.
48 basename = path: with pkgs.lib; last (splitString "/" path);
48 basename = path: with pkgs.lib; last (splitString "/" path);
49
49
50 # source code filter used as arugment to builtins.filterSource.
50 # source code filter used as arugment to builtins.filterSource.
51 src-filter = path: type: with pkgs.lib;
51 src-filter = path: type: with pkgs.lib;
52 let
52 let
53 ext = last (splitString "." path);
53 ext = last (splitString "." path);
54 in
54 in
55 !builtins.elem (basename path) [
55 !builtins.elem (basename path) [
56 ".git" ".hg" "__pycache__" ".eggs" ".idea" ".dev"
56 ".git" ".hg" "__pycache__" ".eggs" ".idea" ".dev"
57 "node_modules" "node_binaries"
57 "node_modules" "node_binaries"
58 "build" "data" "result" "tmp"] &&
58 "build" "data" "result" "tmp"] &&
59 !builtins.elem ext ["egg-info" "pyc"] &&
59 !builtins.elem ext ["egg-info" "pyc"] &&
60 # TODO: johbo: This check is wrong, since "path" contains an absolute path,
60 # TODO: johbo: This check is wrong, since "path" contains an absolute path,
61 # it would still be good to restore it since we want to ignore "result-*".
61 # it would still be good to restore it since we want to ignore "result-*".
62 !hasPrefix "result" path;
62 !hasPrefix "result" path;
63
63
64 sources =
64 sources =
65 let
65 let
66 inherit
66 inherit
67 (pkgs.lib)
67 (pkgs.lib)
68 all
68 all
69 isString
69 isString
70 attrValues;
70 attrValues;
71 sourcesConfig = pkgs.config.rc.sources or {};
71 sourcesConfig = pkgs.config.rc.sources or {};
72 in
72 in
73 # Ensure that sources are configured as strings. Using a path
73 # Ensure that sources are configured as strings. Using a path
74 # would result in a copy into the nix store.
74 # would result in a copy into the nix store.
75 assert all isString (attrValues sourcesConfig);
75 assert all isString (attrValues sourcesConfig);
76 sourcesConfig;
76 sourcesConfig;
77
77
78 version = builtins.readFile "${rhodecode-enterprise-ce-src}/rhodecode/VERSION";
78 version = builtins.readFile "${rhodecode-enterprise-ce-src}/rhodecode/VERSION";
79 rhodecode-enterprise-ce-src = builtins.filterSource src-filter ./.;
79 rhodecode-enterprise-ce-src = builtins.filterSource src-filter ./.;
80
80
81 nodeEnv = import ./pkgs/node-default.nix {
81 nodeEnv = import ./pkgs/node-default.nix {
82 inherit
82 inherit
83 pkgs;
83 pkgs;
84 };
84 };
85 nodeDependencies = nodeEnv.shell.nodeDependencies;
85 nodeDependencies = nodeEnv.shell.nodeDependencies;
86
86
87 rhodecode-testdata-src = sources.rhodecode-testdata or (
87 rhodecode-testdata-src = sources.rhodecode-testdata or (
88 pkgs.fetchhg {
88 pkgs.fetchhg {
89 url = "https://code.rhodecode.com/upstream/rc_testdata";
89 url = "https://code.rhodecode.com/upstream/rc_testdata";
90 rev = "v0.10.0";
90 rev = "v0.10.0";
91 sha256 = "0zn9swwvx4vgw4qn8q3ri26vvzgrxn15x6xnjrysi1bwmz01qjl0";
91 sha256 = "0zn9swwvx4vgw4qn8q3ri26vvzgrxn15x6xnjrysi1bwmz01qjl0";
92 });
92 });
93
93
94 rhodecode-testdata = import "${rhodecode-testdata-src}/default.nix" {
94 rhodecode-testdata = import "${rhodecode-testdata-src}/default.nix" {
95 inherit
95 inherit
96 doCheck
96 doCheck
97 pkgs
97 pkgs
98 pythonPackages;
98 pythonPackages;
99 };
99 };
100
100
101 pythonLocalOverrides = self: super: {
101 pythonLocalOverrides = self: super: {
102 rhodecode-enterprise-ce =
102 rhodecode-enterprise-ce =
103 let
103 let
104 linkNodePackages = ''
104 linkNodePackages = ''
105 export RHODECODE_CE_PATH=${rhodecode-enterprise-ce-src}
105 export RHODECODE_CE_PATH=${rhodecode-enterprise-ce-src}
106
106
107 echo "[BEGIN]: Link node packages and binaries"
107 echo "[BEGIN]: Link node packages and binaries"
108 # johbo: Linking individual packages allows us to run "npm install"
108 # johbo: Linking individual packages allows us to run "npm install"
109 # inside of a shell to try things out. Re-entering the shell will
109 # inside of a shell to try things out. Re-entering the shell will
110 # restore a clean environment.
110 # restore a clean environment.
111 rm -fr node_modules
111 rm -fr node_modules
112 mkdir node_modules
112 mkdir node_modules
113 ln -s ${nodeDependencies}/lib/node_modules/* node_modules/
113 ln -s ${nodeDependencies}/lib/node_modules/* node_modules/
114 export NODE_PATH=./node_modules
114 export NODE_PATH=./node_modules
115
115
116 rm -fr node_binaries
116 rm -fr node_binaries
117 mkdir node_binaries
117 mkdir node_binaries
118 ln -s ${nodeDependencies}/bin/* node_binaries/
118 ln -s ${nodeDependencies}/bin/* node_binaries/
119 echo "[DONE ]: Link node packages and binaries"
119 echo "[DONE ]: Link node packages and binaries"
120 '';
120 '';
121
121
122 releaseName = "RhodeCodeEnterpriseCE-${version}";
122 releaseName = "RhodeCodeEnterpriseCE-${version}";
123 in super.rhodecode-enterprise-ce.override (attrs: {
123 in super.rhodecode-enterprise-ce.override (attrs: {
124 inherit
124 inherit
125 doCheck
125 doCheck
126 version;
126 version;
127
127
128 name = "rhodecode-enterprise-ce-${version}";
128 name = "rhodecode-enterprise-ce-${version}";
129 releaseName = releaseName;
129 releaseName = releaseName;
130 src = rhodecode-enterprise-ce-src;
130 src = rhodecode-enterprise-ce-src;
131 dontStrip = true; # prevent strip, we don't need it.
131 dontStrip = true; # prevent strip, we don't need it.
132
132
133 # expose following attributed outside
133 # expose following attributed outside
134 passthru = {
134 passthru = {
135 inherit
135 inherit
136 rhodecode-testdata
136 rhodecode-testdata
137 linkNodePackages
137 linkNodePackages
138 myPythonPackagesUnfix
138 myPythonPackagesUnfix
139 pythonLocalOverrides
139 pythonLocalOverrides
140 pythonCommunityOverrides;
140 pythonCommunityOverrides;
141
141
142 pythonPackages = self;
142 pythonPackages = self;
143 };
143 };
144
144
145 buildInputs =
145 buildInputs =
146 attrs.buildInputs or [] ++ [
146 attrs.buildInputs or [] ++ [
147 rhodecode-testdata
147 rhodecode-testdata
148 ];
148 ];
149
149
150 #NOTE: option to inject additional propagatedBuildInputs
150 #NOTE: option to inject additional propagatedBuildInputs
151 propagatedBuildInputs =
151 propagatedBuildInputs =
152 attrs.propagatedBuildInputs or [] ++ [
152 attrs.propagatedBuildInputs or [] ++ [
153
153
154 ];
154 ];
155
155
156 LC_ALL = "en_US.UTF-8";
156 LC_ALL = "en_US.UTF-8";
157 LOCALE_ARCHIVE =
157 LOCALE_ARCHIVE =
158 if pkgs.stdenv.isLinux
158 if pkgs.stdenv.isLinux
159 then "${pkgs.glibcLocales}/lib/locale/locale-archive"
159 then "${pkgs.glibcLocales}/lib/locale/locale-archive"
160 else "";
160 else "";
161
161
162 # Add bin directory to path so that tests can find 'rhodecode'.
162 # Add bin directory to path so that tests can find 'rhodecode'.
163 preCheck = ''
163 preCheck = ''
164 export PATH="$out/bin:$PATH"
164 export PATH="$out/bin:$PATH"
165 '';
165 '';
166
166
167 # custom check phase for testing
167 # custom check phase for testing
168 checkPhase = ''
168 checkPhase = ''
169 runHook preCheck
169 runHook preCheck
170 PYTHONHASHSEED=random py.test -vv -p no:sugar -r xw --cov-config=.coveragerc --cov=rhodecode --cov-report=term-missing rhodecode
170 PYTHONHASHSEED=random py.test -vv -p no:sugar -r xw --cov-config=.coveragerc --cov=rhodecode --cov-report=term-missing rhodecode
171 runHook postCheck
171 runHook postCheck
172 '';
172 '';
173
173
174 postCheck = ''
174 postCheck = ''
175 echo "Cleanup of rhodecode/tests"
175 echo "Cleanup of rhodecode/tests"
176 rm -rf $out/lib/${self.python.libPrefix}/site-packages/rhodecode/tests
176 rm -rf $out/lib/${self.python.libPrefix}/site-packages/rhodecode/tests
177 '';
177 '';
178
178
179 preBuild = ''
179 preBuild = ''
180 echo "[BEGIN]: Building frontend assets"
180 echo "[BEGIN]: Building frontend assets"
181 ${linkNodePackages}
181 ${linkNodePackages}
182 make web-build
182 make web-build
183 rm -fr node_modules
183 rm -fr node_modules
184 rm -fr node_binaries
184 rm -fr node_binaries
185 echo "[DONE ]: Building frontend assets"
185 echo "[DONE ]: Building frontend assets"
186 '';
186 '';
187
187
188 postInstall = ''
188 postInstall = ''
189 # check required files
189 # check required files
190 STATIC_CHECK="/robots.txt /502.html
190 STATIC_CHECK="/robots.txt /502.html
191 /js/scripts.js /js/rhodecode-components.js
191 /js/scripts.js /js/rhodecode-components.js
192 /css/style.css /css/style-polymer.css"
192 /css/style.css /css/style-polymer.css"
193
193
194 for file in $STATIC_CHECK;
194 for file in $STATIC_CHECK;
195 do
195 do
196 if [ ! -f rhodecode/public/$file ]; then
196 if [ ! -f rhodecode/public/$file ]; then
197 echo "Missing $file"
197 echo "Missing $file"
198 exit 1
198 exit 1
199 fi
199 fi
200 done
200 done
201
201
202 echo "Writing enterprise-ce meta information for rccontrol to nix-support/rccontrol"
202 echo "Writing enterprise-ce meta information for rccontrol to nix-support/rccontrol"
203 mkdir -p $out/nix-support/rccontrol
203 mkdir -p $out/nix-support/rccontrol
204 cp -v rhodecode/VERSION $out/nix-support/rccontrol/version
204 cp -v rhodecode/VERSION $out/nix-support/rccontrol/version
205 echo "[DONE ]: enterprise-ce meta information for rccontrol written"
205 echo "[DONE ]: enterprise-ce meta information for rccontrol written"
206
206
207 mkdir -p $out/etc
207 mkdir -p $out/etc
208 cp configs/production.ini $out/etc
208 cp configs/production.ini $out/etc
209 echo "[DONE ]: saved enterprise-ce production.ini into $out/etc"
209 echo "[DONE ]: saved enterprise-ce production.ini into $out/etc"
210
210
211 cp -r rhodecode/config/rcextensions $out/etc/rcextensions.tmpl
211 cp -r rhodecode/config/rcextensions $out/etc/rcextensions.tmpl
212 echo "[DONE ]: saved enterprise-ce rcextensions into $out/etc/rcextensions.tmpl"
212 echo "[DONE ]: saved enterprise-ce rcextensions into $out/etc/rcextensions.tmpl"
213
213
214 # python based programs need to be wrapped
214 # python based programs need to be wrapped
215 mkdir -p $out/bin
215 mkdir -p $out/bin
216
216
217 # required binaries from dependencies
217 # required binaries from dependencies
218 ln -s ${self.supervisor}/bin/supervisorctl $out/bin/
218 ln -s ${self.supervisor}/bin/supervisorctl $out/bin/
219 ln -s ${self.supervisor}/bin/supervisord $out/bin/
219 ln -s ${self.supervisor}/bin/supervisord $out/bin/
220 ln -s ${self.pastescript}/bin/paster $out/bin/
220 ln -s ${self.pastescript}/bin/paster $out/bin/
221 ln -s ${self.channelstream}/bin/channelstream $out/bin/
221 ln -s ${self.channelstream}/bin/channelstream $out/bin/
222 ln -s ${self.celery}/bin/celery $out/bin/
222 ln -s ${self.celery}/bin/celery $out/bin/
223 ln -s ${self.gunicorn}/bin/gunicorn $out/bin/
223 ln -s ${self.gunicorn}/bin/gunicorn $out/bin/
224 ln -s ${self.pyramid}/bin/prequest $out/bin/
224 ln -s ${self.pyramid}/bin/prequest $out/bin/
225 ln -s ${self.pyramid}/bin/pserve $out/bin/
225 ln -s ${self.pyramid}/bin/pserve $out/bin/
226
226
227 echo "[DONE ]: created symlinks into $out/bin"
227 echo "[DONE ]: created symlinks into $out/bin"
228 DEPS="$out/bin/supervisorctl \
228 DEPS="$out/bin/supervisorctl \
229 $out/bin/supervisord \
229 $out/bin/supervisord \
230 $out/bin/paster \
230 $out/bin/paster \
231 $out/bin/channelstream \
231 $out/bin/channelstream \
232 $out/bin/celery \
232 $out/bin/celery \
233 $out/bin/gunicorn \
233 $out/bin/gunicorn \
234 $out/bin/prequest \
234 $out/bin/prequest \
235 $out/bin/pserve"
235 $out/bin/pserve"
236
236
237 # wrap only dependency scripts, they require to have full PYTHONPATH set
237 # wrap only dependency scripts, they require to have full PYTHONPATH set
238 # to be able to import all packages
238 # to be able to import all packages
239 for file in $DEPS;
239 for file in $DEPS;
240 do
240 do
241 wrapProgram $file \
241 wrapProgram $file \
242 --prefix PATH : $PATH \
242 --prefix PATH : $PATH \
243 --prefix PYTHONPATH : $PYTHONPATH \
243 --prefix PYTHONPATH : $PYTHONPATH \
244 --set PYTHONHASHSEED random
244 --set PYTHONHASHSEED random
245 done
245 done
246
246
247 echo "[DONE ]: enterprise-ce binary wrapping"
247 echo "[DONE ]: enterprise-ce binary wrapping"
248
248
249 # rhodecode-tools don't need wrapping
249 # rhodecode-tools don't need wrapping
250 ln -s ${self.rhodecode-tools}/bin/rhodecode-* $out/bin/
250 ln -s ${self.rhodecode-tools}/bin/rhodecode-* $out/bin/
251
251
252 # expose sources of CE
252 # expose sources of CE
253 ln -s $out $out/etc/rhodecode_enterprise_ce_source
253 ln -s $out $out/etc/rhodecode_enterprise_ce_source
254
254
255 # expose static files folder
255 # expose static files folder
256 cp -Rf $out/lib/${self.python.libPrefix}/site-packages/rhodecode/public/ $out/etc/static
256 cp -Rf $out/lib/${self.python.libPrefix}/site-packages/rhodecode/public/ $out/etc/static
257 chmod 755 -R $out/etc/static
257 chmod 755 -R $out/etc/static
258
258
259 '';
259 '';
260 });
260 });
261
261
262 };
262 };
263
263
264 basePythonPackages = with builtins;
264 basePythonPackages = with builtins;
265 if isAttrs pythonPackages then
265 if isAttrs pythonPackages then
266 pythonPackages
266 pythonPackages
267 else
267 else
268 getAttr pythonPackages pkgs;
268 getAttr pythonPackages pkgs;
269
269
270 pythonGeneratedPackages = import ./pkgs/python-packages.nix {
270 pythonGeneratedPackages = import ./pkgs/python-packages.nix {
271 inherit
271 inherit
272 pkgs;
272 pkgs;
273 inherit
273 inherit
274 (pkgs)
274 (pkgs)
275 fetchurl
275 fetchurl
276 fetchgit
276 fetchgit
277 fetchhg;
277 fetchhg;
278 };
278 };
279
279
280 pythonCommunityOverrides = import ./pkgs/python-packages-overrides.nix {
280 pythonCommunityOverrides = import ./pkgs/python-packages-overrides.nix {
281 inherit pkgs basePythonPackages;
281 inherit pkgs basePythonPackages;
282 };
282 };
283
283
284 # Apply all overrides and fix the final package set
284 # Apply all overrides and fix the final package set
285 myPythonPackagesUnfix = with pkgs.lib;
285 myPythonPackagesUnfix = with pkgs.lib;
286 (extends pythonExternalOverrides
286 (extends pythonExternalOverrides
287 (extends pythonLocalOverrides
287 (extends pythonLocalOverrides
288 (extends pythonCommunityOverrides
288 (extends pythonCommunityOverrides
289 (extends pythonGeneratedPackages
289 (extends pythonGeneratedPackages
290 basePythonPackagesUnfix))));
290 basePythonPackagesUnfix))));
291
291
292 myPythonPackages = (pkgs.lib.fix myPythonPackagesUnfix);
292 myPythonPackages = (pkgs.lib.fix myPythonPackagesUnfix);
293
293
294 in myPythonPackages.rhodecode-enterprise-ce
294 in myPythonPackages.rhodecode-enterprise-ce
@@ -1,21 +1,19 b''
1 # This file defines how to "build" for packaging.
1 # This file defines how to "build" for packaging.
2
2
3 { pkgs ? import <nixpkgs> {}
3 { doCheck ? false
4 , doCheck ? false
5 }:
4 }:
6
5
7 let
6 let
8 enterprise_ce = import ./default.nix {
7 enterprise_ce = import ./default.nix {
9 inherit
8 inherit
10 doCheck
9 doCheck;
11 pkgs;
12
10
13 # disable checkPhase for build
11 # disable checkPhase for build
14 checkPhase = ''
12 checkPhase = ''
15 '';
13 '';
16
14
17 };
15 };
18
16
19 in {
17 in {
20 build = enterprise_ce;
18 build = enterprise_ce;
21 }
19 }
General Comments 0
You need to be logged in to leave comments. Login now