So the issue for me was a failed install of Pillow 7.2.0 which I only found by looking at the HA logs on the DietPi install as the official image doesn’t have SSH enabled.
Issue was with prerequisites on Pillow 7.2.0, namely:
The headers or library files could not be found for jpeg,
a required dependency when compiling Pillow from source.
homeassistant@DietPi:~$ python3 -m pip install --upgrade Pillow
Looking in indexes: https://pypi.org/simple, https://www.piwheels.org/simple
Collecting Pillow
Using cached Pillow-7.2.0.tar.gz (39.1 MB)
Building wheels for collected packages: Pillow
Building wheel for Pillow (setup.py) ... error
ERROR: Command errored out with exit status 1:
command: /home/homeassistant/.pyenv/versions/3.8.0/bin/python3 -u -c 'import sys, setuptools, tokenize; sys.argv[0] = '"'"'/tmp/pip-install-9w1cfixb/pillow/setup.py'"'"'; __file__='"'"'/tmp/pip-install-9w1cfixb/pillow/setup.py'"'"';f=getattr(tokenize, '"'"'open'"'"', open)(__file__);code=f.read().replace('"'"'\r\n'"'"', '"'"'\n'"'"');f.close();exec(compile(code, __file__, '"'"'exec'"'"'))' bdist_wheel -d /tmp/pip-wheel-1qcfl8vn
cwd: /tmp/pip-install-9w1cfixb/pillow/
Complete output (170 lines):
running bdist_wheel
running build
running build_py
creating build
creating build/lib.linux-armv7l-3.8
creating build/lib.linux-armv7l-3.8/PIL
copying src/PIL/features.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/_version.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/_util.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/_tkinter_finder.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/_binary.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/__main__.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/__init__.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/XpmImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/XbmImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/XVThumbImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/WmfImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/WebPImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/WalImageFile.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/TiffTags.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/TiffImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/TgaImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/TarIO.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/SunImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/SpiderImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/SgiImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/PyAccess.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/PsdImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/PpmImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/PngImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/PixarImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/PdfParser.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/PdfImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/PcxImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/PcfFontFile.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/PcdImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/PalmImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/PaletteFile.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/PSDraw.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/MspImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/MpoImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/MpegImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/MicImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/McIdasImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/JpegPresets.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/JpegImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/Jpeg2KImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/IptcImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImtImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageWin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageTransform.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageTk.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageStat.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageShow.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageSequence.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageQt.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImagePath.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImagePalette.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageOps.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageMorph.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageMode.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageMath.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageGrab.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageFont.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageFilter.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageFile.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageEnhance.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageDraw2.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageDraw.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageColor.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageCms.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImageChops.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/Image.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ImImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/IcoImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/IcnsImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/Hdf5StubImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/GribStubImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/GimpPaletteFile.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/GimpGradientFile.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/GifImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/GdImageFile.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/GbrImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/FtexImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/FpxImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/FontFile.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/FliImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/FitsStubImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ExifTags.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/EpsImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/DdsImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/DcxImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/CurImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/ContainerIO.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/BufrStubImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/BmpImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/BlpImagePlugin.py -> build/lib.linux-armv7l-3.8/PIL
copying src/PIL/BdfFontFile.py -> build/lib.linux-armv7l-3.8/PIL
running egg_info
writing src/Pillow.egg-info/PKG-INFO
writing dependency_links to src/Pillow.egg-info/dependency_links.txt
writing top-level names to src/Pillow.egg-info/top_level.txt
reading manifest file 'src/Pillow.egg-info/SOURCES.txt'
reading manifest template 'MANIFEST.in'
warning: no files found matching '*.c'
warning: no files found matching '*.h'
warning: no files found matching '*.sh'
warning: no previously-included files found matching '.appveyor.yml'
warning: no previously-included files found matching '.coveragerc'
warning: no previously-included files found matching '.editorconfig'
warning: no previously-included files found matching '.readthedocs.yml'
warning: no previously-included files found matching 'codecov.yml'
warning: no previously-included files matching '.git*' found anywhere in distribution
warning: no previously-included files matching '*.pyc' found anywhere in distribution
warning: no previously-included files matching '*.so' found anywhere in distribution
no previously-included directories found matching '.ci'
writing manifest file 'src/Pillow.egg-info/SOURCES.txt'
running build_ext
The headers or library files could not be found for jpeg,
a required dependency when compiling Pillow from source.
Please see the install instructions at:
https://pillow.readthedocs.io/en/latest/installation.html
Traceback (most recent call last):
File "/tmp/pip-install-9w1cfixb/pillow/setup.py", line 864, in <module>
setup(
File "/home/homeassistant/.pyenv/versions/3.8.0/lib/python3.8/site-packages/setuptools/__init__.py", line 145, in setup
return distutils.core.setup(**attrs)
File "/home/homeassistant/.pyenv/versions/3.8.0/lib/python3.8/distutils/core.py", line 148, in setup
dist.run_commands()
File "/home/homeassistant/.pyenv/versions/3.8.0/lib/python3.8/distutils/dist.py", line 966, in run_commands
self.run_command(cmd)
File "/home/homeassistant/.pyenv/versions/3.8.0/lib/python3.8/distutils/dist.py", line 985, in run_command
cmd_obj.run()
File "/home/homeassistant/.pyenv/versions/3.8.0/lib/python3.8/site-packages/wheel/bdist_wheel.py", line 290, in run
self.run_command('build')
File "/home/homeassistant/.pyenv/versions/3.8.0/lib/python3.8/distutils/cmd.py", line 313, in run_command
self.distribution.run_command(command)
File "/home/homeassistant/.pyenv/versions/3.8.0/lib/python3.8/distutils/dist.py", line 985, in run_command
cmd_obj.run()
File "/home/homeassistant/.pyenv/versions/3.8.0/lib/python3.8/distutils/command/build.py", line 135, in run
self.run_command(cmd_name)
File "/home/homeassistant/.pyenv/versions/3.8.0/lib/python3.8/distutils/cmd.py", line 313, in run_command
self.distribution.run_command(command)
File "/home/homeassistant/.pyenv/versions/3.8.0/lib/python3.8/distutils/dist.py", line 985, in run_command
cmd_obj.run()
File "/home/homeassistant/.pyenv/versions/3.8.0/lib/python3.8/distutils/command/build_ext.py", line 340, in run
self.build_extensions()
File "/tmp/pip-install-9w1cfixb/pillow/setup.py", line 694, in build_extensions
raise RequiredDependencyException(f)
__main__.RequiredDependencyException: jpeg
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "<string>", line 1, in <module>
File "/tmp/pip-install-9w1cfixb/pillow/setup.py", line 918, in <module>
raise RequiredDependencyException(msg)
__main__.RequiredDependencyException:
The headers or library files could not be found for jpeg,
a required dependency when compiling Pillow from source.
Please see the install instructions at:
https://pillow.readthedocs.io/en/latest/installation.html
----------------------------------------
ERROR: Failed building wheel for Pillow
Running setup.py clean for Pillow
Failed to build Pillow
Solved by manually installing:
homeassistant@DietPi:~$ sudo apt-get install libjpeg-dev zlib1g-dev
Reading package lists... Done
Building dependency tree
Reading state information... Done
zlib1g-dev is already the newest version (1:1.2.11.dfsg-1).
The following additional packages will be installed:
libjpeg62-turbo libjpeg62-turbo-dev
The following NEW packages will be installed:
libjpeg-dev libjpeg62-turbo libjpeg62-turbo-dev
0 upgraded, 3 newly installed, 0 to remove and 0 not upgraded.
Need to get 346 kB of archives.
After this operation, 813 kB of additional disk space will be used.
Do you want to continue? [Y/n] y
Get:1 http://mirror.internode.on.net/pub/raspbian/raspbian buster/main armhf libjpeg62-turbo armhf 1:1.5.2-2+b1 [110 kB]
Get:2 http://mirror.internode.on.net/pub/raspbian/raspbian buster/main armhf libjpeg62-turbo-dev armhf 1:1.5.2-2+b1 [179 kB]
Get:3 http://mirror.datamossa.io/raspbian buster/main armhf libjpeg-dev all 1:1.5.2-2 [57.5 kB]
Fetched 346 kB in 2s (142 kB/s)
debconf: delaying package configuration, since apt-utils is not installed
Selecting previously unselected package libjpeg62-turbo:armhf.
(Reading database ... 26346 files and directories currently installed.)
Preparing to unpack .../libjpeg62-turbo_1%3a1.5.2-2+b1_armhf.deb ...
Unpacking libjpeg62-turbo:armhf (1:1.5.2-2+b1) ...
Selecting previously unselected package libjpeg62-turbo-dev:armhf.
Preparing to unpack .../libjpeg62-turbo-dev_1%3a1.5.2-2+b1_armhf.deb ...
Unpacking libjpeg62-turbo-dev:armhf (1:1.5.2-2+b1) ...
Selecting previously unselected package libjpeg-dev.
Preparing to unpack .../libjpeg-dev_1%3a1.5.2-2_all.deb ...
Unpacking libjpeg-dev (1:1.5.2-2) ...
Setting up libjpeg62-turbo:armhf (1:1.5.2-2+b1) ...
Setting up libjpeg62-turbo-dev:armhf (1:1.5.2-2+b1) ...
Setting up libjpeg-dev (1:1.5.2-2) ...
Processing triggers for libc-bin (2.28-10+rpi1) ...
And then:
homeassistant@DietPi:~$ pip3.8 install pillow==7.2.0