Skip to content
This repository was archived by the owner on Jan 30, 2023. It is now read-only.

Commit 97557e1

Browse files
author
Matthias Koeppe
committed
Merge tag '9.7.beta3' into t/32423/update_numpy_to_1_22_x__scipy_1_8_x___requires_dropping_python_3_7
SageMath version 9.7.beta3, Release Date: 2022-06-19
2 parents acdebee + f8df808 commit 97557e1

File tree

1,088 files changed

+7758
-8679
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

1,088 files changed

+7758
-8679
lines changed

.github/workflows/build.yml

+14-2
Original file line numberDiff line numberDiff line change
@@ -29,11 +29,13 @@ jobs:
2929

3030
- name: Prepare
3131
run: |
32+
# Install test tools.
33+
# Installation of python3-venv can be removed as soon as a
34+
# base image with a release including #33822 is available
35+
apt-get install -y git python3-venv
3236
# Reuse built SAGE_LOCAL contained in the Docker image
3337
./bootstrap
3438
./configure --enable-build-as-root --prefix=/sage/local --with-sage-venv --enable-editable --enable-download-from-upstream-url
35-
# Install test tools
36-
apt-get install -y git
3739
3840
- name: Static code check with pyright
3941
run: pyright
@@ -44,6 +46,16 @@ jobs:
4446
MAKE: make -j2
4547
SAGE_NUM_THREADS: 2
4648

49+
- name: Pytest
50+
if: contains(github.ref, 'pytest')
51+
run: |
52+
../sage -python -m pip install coverage pytest-xdist
53+
../sage -python -m coverage run -m pytest -c tox.ini --doctest-modules || true
54+
working-directory: ./src
55+
env:
56+
# Increase the length of the lines in the "short summary"
57+
COLUMNS: 120
58+
4759
- name: Test
4860
run: |
4961
../sage -python -m pip install coverage

.github/workflows/doc-build.yml

+1
Original file line numberDiff line numberDiff line change
@@ -24,6 +24,7 @@ jobs:
2424
# Reuse built SAGE_LOCAL contained in the Docker image
2525
./bootstrap
2626
./configure --enable-build-as-root --prefix=/sage/local --with-sage-venv --enable-download-from-upstream-url
27+
make furo
2728
2829
- name: Build
2930
run: make doc-html

.github/workflows/tox.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -38,7 +38,7 @@ jobs:
3838
fail-fast: false
3939
max-parallel: 20
4040
matrix:
41-
tox_system_factor: [gitpod, ubuntu-trusty-toolchain-gcc_9, ubuntu-xenial-toolchain-gcc_9, ubuntu-bionic, ubuntu-focal, ubuntu-hirsute, ubuntu-impish, ubuntu-jammy, ubuntu-kinetic, debian-stretch, debian-buster, debian-bullseye, debian-bookworm, debian-sid, linuxmint-19, linuxmint-19.3, linuxmint-20.1, linuxmint-20.2, linuxmint-20.3, linuxmint-21, fedora-26, fedora-27, fedora-28, fedora-29, fedora-30, fedora-31, fedora-32, fedora-33, fedora-34, fedora-35, fedora-36, fedora-37, centos-7-devtoolset-gcc_11, centos-stream-8, gentoo-python3.9, gentoo-python3.10, archlinux-latest, opensuse-15.3, opensuse-tumbleweed, conda-forge, ubuntu-bionic-i386, manylinux-2_24-i686, debian-buster-i386, centos-7-i386-devtoolset-gcc_11]
41+
tox_system_factor: [ubuntu-trusty-toolchain-gcc_9, ubuntu-xenial-toolchain-gcc_9, ubuntu-bionic, ubuntu-focal, ubuntu-hirsute, ubuntu-impish, ubuntu-jammy, ubuntu-kinetic, debian-stretch, debian-buster, debian-bullseye, debian-bookworm, debian-sid, linuxmint-19, linuxmint-19.3, linuxmint-20.1, linuxmint-20.2, linuxmint-20.3, linuxmint-21, fedora-26, fedora-27, fedora-28, fedora-29, fedora-30, fedora-31, fedora-32, fedora-33, fedora-34, fedora-35, fedora-36, fedora-37, centos-7-devtoolset-gcc_11, centos-stream-8, gentoo-python3.9, gentoo-python3.10, archlinux-latest, opensuse-15.3, opensuse-tumbleweed, conda-forge, ubuntu-bionic-i386, manylinux-2_24-i686, debian-buster-i386, centos-7-i386-devtoolset-gcc_11]
4242
tox_packages_factor: [minimal, standard]
4343
env:
4444
TOX_ENV: docker-${{ matrix.tox_system_factor }}-${{ matrix.tox_packages_factor }}

.gitignore

+7
Original file line numberDiff line numberDiff line change
@@ -166,10 +166,16 @@ build/bin/sage-build-env-config
166166

167167
/pkgs/sagemath-objects/setup.cfg
168168
/pkgs/sagemath-categories/setup.cfg
169+
/pkgs/sagemath-environment/setup.cfg
170+
/pkgs/sagemath-repl/setup.cfg
169171
/pkgs/sagemath-objects/pyproject.toml
170172
/pkgs/sagemath-categories/pyproject.toml
173+
/pkgs/sagemath-environment/pyproject.toml
174+
/pkgs/sagemath-repl/pyproject.toml
171175
/pkgs/sagemath-objects/requirements.txt
172176
/pkgs/sagemath-categories/requirements.txt
177+
/pkgs/sagemath-environment/requirements.txt
178+
/pkgs/sagemath-repl/requirements.txt
173179
/pkgs/sagemath-categories/MANIFEST.in
174180

175181
# same for old locations - before Trac #31577
@@ -181,6 +187,7 @@ build/bin/sage-build-env-config
181187

182188
# Generated by docbuild
183189
/src/doc/en/reference/*/sage
190+
/src/doc/en/reference/*/sage_docbuild
184191
/src/doc/en/reference/sage
185192
/src/doc/en/reference/spkg/*.rst
186193
/src/doc/output

.gitpod.yml

+27-70
Original file line numberDiff line numberDiff line change
@@ -1,41 +1,32 @@
11
# Use custom docker image. https://www.gitpod.io/docs/config-docker
22
image:
3-
# Each of these two options works:
4-
# - Directly use the "-with-targets" image built by .github/workflows/tox.yml
5-
# image: ghcr.io/sagemath/sage/sage-docker-gitpod-standard-with-targets:dev
6-
# - or go through a custom Dockerfile, which builds a smaller image
7-
# based on the "-with-system-packages" image built by .github/workflows/tox.yml
8-
# with the built SAGE_LOCAL from the "-with-targets" image copied in.
9-
file: docker/.gitpod.Dockerfile
10-
11-
# We use the following layout:
12-
#
13-
# $HOME/sage Source tree used by the Docker build; see SAGE_ROOT/tox.ini (gitpod).
14-
# - We delete it in every invocation of the 'before' script
15-
# and replace it by a symlink to /workspace/...
16-
# (This symlink is needed because the package-removal scripts
17-
# ({prefix,venv}/var/lib/sage/scripts/*/{spkg-piprm,spkg-prerm,spkg-postrm)
18-
# hardcode SAGE_ROOT and SAGE_SRC from package installation time)
19-
# $HOME/sage/logs Logs of the Docker build.
20-
# - In the first invocation of the 'before' script, we move it
21-
# to /workspace/.../logs
22-
# $HOME/sage-local The configured prefix (SAGE_LOCAL) of the Sage installation.
23-
# - During the Docker build, this is the physical location.
24-
# - In the first invocation of the 'before' script, we move it
25-
# to the new physical location /workspace/.../local
26-
# (because gitpod only preserves the contents of /workspace)
27-
# and replace it by a symlink to the new physical location.
28-
# - In subsequent invocations of the 'before' script, we
29-
# remove it and replace it by a symlink to the physical
30-
# location /workspace/.../local
31-
# /worktree/.../local The physical location of the Sage installation,
32-
# established in the first run of the 'before' script and
33-
# preserved by gitpod.
3+
file: docker/.gitpod.Dockerfile
344

355
# Start up tasks. https://www.gitpod.io/docs/config-start-tasks/
366
tasks:
377
- name: Setup
38-
before: |
8+
init: |
9+
# Create conda environment
10+
./bootstrap-conda
11+
mamba env create --file src/environment-dev.yml --prefix venv
12+
conda config --append envs_dirs /workspace/sagetrac-mirror
13+
conda activate /workspace/sagetrac-mirror/venv
14+
15+
# Build sage
16+
./bootstrap
17+
./configure --enable-build-as-root --with-python=$CONDA_PREFIX/bin/python --prefix=$CONDA_PREFIX
18+
pip install --no-build-isolation -v -v -e ./pkgs/sage-conf ./pkgs/sage-setup
19+
pip install --no-build-isolation -v -v -e ./src
20+
21+
command: |
22+
# Activate conda environment
23+
conda config --append envs_dirs /workspace/sagetrac-mirror
24+
conda activate /workspace/sagetrac-mirror/venv
25+
26+
# RestructuredText extension recommends python extension, although we have already installed it
27+
## So disable the recommendation dialog
28+
echo "{\"restructuredtext.pythonRecommendation.disabled\": true}" > /workspace/.vscode-remote/data/Machine/settings.json
29+
3930
# Setup trac as remote
4031
## In order to push to trac, generate a new key with `ssh-keygen -f tempkey` and save the private key to gitpod `gp env PRIVATE_SSH_KEY="$(<tempkey)"` (or by following https://www.gitpod.io/docs/environment-variables#using-the-account-settings)
4132
## then follow https://doc.sagemath.org/html/en/developer/trac.html#linking-your-public-key-to-your-trac-account to register the public key with trac.
@@ -47,7 +38,7 @@ tasks:
4738
echo $PRIVATE_SSH_KEY | sed 's/\(-----\(BEGIN\|END\) OPENSSH PRIVATE KEY-----\)/\n\1\n/g' > ~/.ssh/id_rsa
4839
sed -i '/^$/d' ~/.ssh/id_rsa
4940
chmod 600 ~/.ssh/id_rsa
50-
unset PRIVATE_SSH_KEY
41+
echo "PubkeyAcceptedKeyTypes +ssh-rsa" > ~/.ssh/config
5142
ssh-keyscan -H trac.sagemath.org >> ~/.ssh/known_hosts
5243
5344
# Setup trac repo
@@ -60,43 +51,7 @@ tasks:
6051
git remote add trac https://github.com/sagemath/sagetrac-mirror.git -t master -t develop
6152
git remote set-url --push trac pushing-needs-ssh-key
6253
fi
63-
64-
## No need for pyenv
65-
pyenv shell --unset 2> /dev/null
66-
pyenv global system 2> /dev/null
67-
if [ -d local ]; then
68-
mkdir -p logs && echo '### .gitpod.yml Setup.before: Prebuild init script has been run. Running "make" again in case the build had timed out.' >> logs/install.log
69-
# The init script has already populated the SAGE_LOCAL,
70-
# but only /workspace is preserved; and the $HOME/sage-local may contain a resurrected
71-
# copy of sage-local. Replace it again by a symlink.
72-
rm -Rf $HOME/sage-local
73-
ln -sf $(pwd)/local $HOME/sage-local
74-
# Now run make. No timeout here.
75-
MAKE='make -j24' make build V=0
76-
else
77-
# Prebuild init script has not been run
78-
# Only /workspace is preserved during build.
79-
# If the Docker image contains a built SAGE_LOCAL, use it to populate the SAGE_LOCAL in the workspace.
80-
if [ -d $HOME/sage-local ]; then
81-
mv $HOME/sage-local local
82-
fi
83-
rm -Rf $HOME/sage-local
84-
ln -sf $(pwd)/local $HOME/sage-local
85-
# Save the logs of the source tree used by the Docker build
86-
if [ -d $HOME/sage/logs ]; then
87-
mv $HOME/sage/logs logs
88-
fi
89-
fi
90-
# Remove the source tree used by the Docker build and replace it by a symlink
91-
rm -Rf $HOME/sage
92-
ln -s $(pwd) $HOME/sage
93-
init: |
94-
# Start build
95-
mkdir -p logs && echo '### .gitpod.yml Setup.init: Starting build' >> logs/install.log
96-
./bootstrap
97-
./configure --enable-editable --enable-download-from-upstream-url --prefix=$HOME/sage-local --with-sage-venv
98-
## Gitpod has a timeout of 1h, so make sure we are below this to ensure that the prebuild is always successful
99-
MAKE='make -j24' timeout 51m make build V=0 || echo "(ignoring error)"
54+
10055
env:
10156
SAGE_NUM_THREADS: 8
10257

@@ -109,6 +64,8 @@ vscode:
10964
- lextudio.restructuredtext
11065
- streetsidesoftware.code-spell-checker
11166
- ms-toolsai.jupyter
67+
- ms-toolsai.jupyter-keymap
68+
- ms-toolsai.jupyter-renderers
11269

11370
# https://www.gitpod.io/docs/prebuilds#github-specific-configuration
11471
github:

.vscode/settings.json

+3
Original file line numberDiff line numberDiff line change
@@ -21,7 +21,10 @@
2121
"--doctest-modules",
2222
],
2323
"python.testing.unittestEnabled": false,
24+
"python.linting.pycodestyleEnabled": true,
25+
"python.linting.enabled": true,
2426
"cSpell.words": [
27+
"furo"
2528
"Conda",
2629
"Cython"
2730
],

.zenodo.json

+4-4
Original file line numberDiff line numberDiff line change
@@ -1,10 +1,10 @@
11
{
22
"description": "Mirror of the Sage https://sagemath.org/ source tree",
33
"license": "other-open",
4-
"title": "sagemath/sage: 9.7.beta1",
5-
"version": "9.7.beta1",
4+
"title": "sagemath/sage: 9.7.beta3",
5+
"version": "9.7.beta3",
66
"upload_type": "software",
7-
"publication_date": "2022-05-26",
7+
"publication_date": "2022-06-19",
88
"creators": [
99
{
1010
"affiliation": "SageMath.org",
@@ -15,7 +15,7 @@
1515
"related_identifiers": [
1616
{
1717
"scheme": "url",
18-
"identifier": "https://github.com/sagemath/sage/tree/9.7.beta1",
18+
"identifier": "https://github.com/sagemath/sage/tree/9.7.beta3",
1919
"relation": "isSupplementTo"
2020
},
2121
{

Makefile

+2-1
Original file line numberDiff line numberDiff line change
@@ -87,6 +87,8 @@ pypi-sdists: sage_setup
8787
./sage --sh build/pkgs/sagelib/spkg-src
8888
./sage --sh build/pkgs/sagemath_objects/spkg-src
8989
./sage --sh build/pkgs/sagemath_categories/spkg-src
90+
./sage --sh build/pkgs/sagemath_environment/spkg-src
91+
./sage --sh build/pkgs/sagemath_repl/spkg-src
9092
@echo "Built sdists are in upstream/"
9193

9294
# ssl: build Sage, and also install pyOpenSSL. This is necessary for
@@ -168,7 +170,6 @@ bootstrap-clean:
168170
rm -rf config configure build/make/Makefile-auto.in
169171
rm -f src/doc/en/installation/*.txt
170172
rm -rf src/doc/en/reference/spkg/*.rst
171-
rm -f src/doc/en/reference/repl/*.txt
172173
rm -f environment.yml
173174
rm -f src/environment.yml
174175
rm -f src/environment-dev.yml

VERSION.txt

+1-1
Original file line numberDiff line numberDiff line change
@@ -1 +1 @@
1-
SageMath version 9.7.beta1, Release Date: 2022-05-26
1+
SageMath version 9.7.beta3, Release Date: 2022-06-19

bootstrap

+7-8
Original file line numberDiff line numberDiff line change
@@ -85,12 +85,12 @@ bootstrap () {
8585
rm -f m4/sage_spkg_configures.m4
8686
spkg_configures=""
8787
# initialize SAGE_ENABLE... options for standard packages
88-
for pkgname in $(./sage --package list :standard: | sort); do
88+
for pkgname in $(sage-package list :standard: | sort); do
8989
spkg_configures="$spkg_configures
9090
AS_VAR_SET_IF([SAGE_ENABLE_$pkgname], [], [AS_VAR_SET([SAGE_ENABLE_$pkgname], [yes])])"
9191
done
9292
# --enable-SPKG options
93-
for pkgname in $(./sage --package list :optional: :experimental: | sort); do
93+
for pkgname in $(sage-package list :optional: :experimental: | sort); do
9494
# Trac #29629: Temporary solution for Sage 9.1: Do not provide
9595
# --enable-SPKG options for installing pip packages
9696
if [ ! -f build/pkgs/$pkgname/requirements.txt ]; then
@@ -109,12 +109,12 @@ SAGE_SPKG_ENABLE([$pkgname], [$pkgtype], [$(grep -v ^= build/pkgs/$pkgname/SPKG.
109109
esac
110110
fi
111111
done
112-
for pkgname in $(./sage --package list --has-file spkg-configure.m4 | sort); do
112+
for pkgname in $(sage-package list --has-file spkg-configure.m4 | sort); do
113113
echo "m4_sinclude([build/pkgs/$pkgname/spkg-configure.m4])"
114114
spkg_configures="$spkg_configures
115115
SAGE_SPKG_CONFIGURE_$(echo ${pkgname} | tr '[a-z]' '[A-Z]')"
116116
done >> m4/sage_spkg_configures.m4
117-
for pkgname in $(./sage --package list | sort); do
117+
for pkgname in $(sage-package list | sort); do
118118
DIR=build/pkgs/$pkgname
119119
pkgtype="$(cat $DIR/type)"
120120
if test -f "$DIR/requirements.txt"; then
@@ -143,7 +143,7 @@ SAGE_SPKG_FINALIZE([$pkgname], [$pkgtype], [$SPKG_SOURCE], [$SPKG_TREE_VAR])"
143143
done
144144
echo "$spkg_configures" >> m4/sage_spkg_configures.m4
145145

146-
for pkgname in $(./sage --package list --has-file bootstrap); do
146+
for pkgname in $(sage-package list --has-file bootstrap); do
147147
(cd build/pkgs/$pkgname && ./bootstrap) || exit 1
148148
done
149149

@@ -247,7 +247,6 @@ save () {
247247
build/make/Makefile-auto.in \
248248
src/doc/en/installation/*.txt \
249249
src/doc/en/reference/spkg/*.rst \
250-
src/doc/en/reference/repl/*.txt \
251250
environment.yml \
252251
src/environment.yml \
253252
environment-optional.yml \
@@ -262,10 +261,10 @@ save () {
262261

263262
# Compute checksum
264263
if [ "${BOOTSTRAP_QUIET}" = "no" ]; then
265-
./sage --package fix-checksum configure
264+
sage-package fix-checksum configure
266265
else
267266
# Hide the "Updating checksum..." message
268-
./sage --package fix-checksum configure > /dev/null
267+
sage-package fix-checksum configure > /dev/null
269268
fi
270269
}
271270

bootstrap-conda

+4-1
Original file line numberDiff line numberDiff line change
@@ -4,6 +4,8 @@
44
# Generate auto-generated conda environment files
55
#########################################################################
66

7+
export PATH="$(pwd)/build/bin:$PATH"
8+
79
STRIP_COMMENTS="sed s/#.*//;"
810
RECOMMENDED_SPKG_PATTERN="@(_recommended$(for a in $(head -n 1 build/pkgs/_recommended/dependencies); do echo -n "|"$a; done))"
911

@@ -13,7 +15,7 @@ OPTIONAL_SYSTEM_PACKAGES=
1315
SAGELIB_SYSTEM_PACKAGES=
1416
SAGELIB_OPTIONAL_SYSTEM_PACKAGES=
1517
RECOMMENDED_SYSTEM_PACKAGES=
16-
for PKG_BASE in $(./sage --package list --has-file distros/conda.txt); do
18+
for PKG_BASE in $(sage-package list --has-file distros/conda.txt); do
1719
PKG_SCRIPTS=build/pkgs/$PKG_BASE
1820
SYSTEM_PACKAGES_FILE=$PKG_SCRIPTS/distros/conda.txt
1921
PKG_TYPE=$(cat $PKG_SCRIPTS/type)
@@ -65,6 +67,7 @@ echo " # Additional dev tools" >> src/environment-dev.yml
6567
echo " - openssh" >> src/environment-dev.yml
6668
echo " - pycodestyle" >> src/environment-dev.yml
6769
echo " - pytest" >> src/environment-dev.yml
70+
echo " - esbonio" >> src/environment-dev.yml
6871

6972
cp environment.yml environment-optional.yml
7073
echo " # optional packages" >> environment-optional.yml

build/bin/sage-bootstrap-python

+11-1
Original file line numberDiff line numberDiff line change
@@ -11,7 +11,17 @@ if [ -z "$SAGE_ORIG_PATH" ]; then
1111
# If not we're running from within sage-env just set the existing path
1212
SAGE_ORIG_PATH="$PATH"
1313
fi
14-
14+
IFS=':'
15+
NEW_PATH=""
16+
for path in $SAGE_ORIG_PATH
17+
do
18+
case "$path" in
19+
*/.pyenv/shims*);;
20+
*) NEW_PATH="$NEW_PATH$path:";;
21+
esac
22+
done
23+
unset IFS
24+
SAGE_ORIG_PATH=${NEW_PATH%%':'}
1525
# In particular, it is invoked by "bootstrap -d" for sage-download-file,
1626
# i.e., before a configure run, and by "sage-spkg", also for sage-download-file.
1727
# So it needs to find a python that has the urllib module.

0 commit comments

Comments
 (0)