You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
As a part of updating XBlock documentation, I created a simple xblock using edx-cookiecutters with a --no-input flag to test the xblock installation. Mounted the xblock using tutor mounts add /home/emad/Desktop/my-xblock, and checked the mounted path:
And a translation directory is linked to this directory.
After I run tutor images build opened-dev, following error will raise:
6.033 python manage.py lms --settings=tutor.assets collectstatic --noinput > /dev/null
9.647 Traceback (most recent call last):
9.647 File "manage.py", line 106, in <module>
9.647 execute_from_command_line([sys.argv[0]] + django_args)
9.647 File "/openedx/venv/lib/python3.8/site-packages/django/core/management/__init__.py", line 442, in execute_from_command_line
9.647 utility.execute()
9.647 File "/openedx/venv/lib/python3.8/site-packages/django/core/management/__init__.py", line 436, in execute
9.647 self.fetch_command(subcommand).run_from_argv(self.argv)
9.647 File "/openedx/venv/lib/python3.8/site-packages/django/core/management/base.py", line 412, in run_from_argv
9.647 self.execute(*args, **cmd_options)
9.647 File "/openedx/venv/lib/python3.8/site-packages/django/core/management/base.py", line 458, in execute
9.647 output = self.handle(*args, **options)
9.647 File "/openedx/venv/lib/python3.8/site-packages/django/contrib/staticfiles/management/commands/collectstatic.py", line 209, in handle
9.647 collected = self.collect()
9.647 File "/openedx/venv/lib/python3.8/site-packages/django/contrib/staticfiles/management/commands/collectstatic.py", line 135, in collect
9.647 handler(path, prefixed_path, storage)
9.647 File "/openedx/venv/lib/python3.8/site-packages/django/contrib/staticfiles/management/commands/collectstatic.py", line 377, in copy_file
9.647 with source_storage.open(path) as source_file:
9.647 File "/openedx/edx-platform/openedx/core/lib/xblock_pipeline/finder.py", line 72, in open
9.647 return FileSystemStorage(path).open(path, mode)
9.647 File "/openedx/venv/lib/python3.8/site-packages/django/core/files/storage/base.py", line 22, in open
9.647 return self._open(name, mode)
9.647 File "/openedx/venv/lib/python3.8/site-packages/django/core/files/storage/filesystem.py", line 68, in _open
9.647 return File(open(self.path(name), mode))
9.647 FileNotFoundError: [Errno 2] No such file or directory: '/mnt/my-xblock/my_xblock/translation'
10.16 Traceback (most recent call last):
10.16 File "/openedx/bin/openedx-assets", line 218, in <module>
10.16 main()
10.16 File "/openedx/bin/openedx-assets", line 89, in main
10.16 args.func(args)
10.16 File "/openedx/bin/openedx-assets", line 157, in run_collect
10.16 assets.collect_assets(args.systems, args.settings)
10.16 File "/openedx/edx-platform/pavelib/assets.py", line 606, in collect_assets
10.16 sh(django_cmd(sys, settings, "collectstatic --noinput {logfile_str}".format(
10.16 File "/openedx/venv/lib/python3.8/site-packages/paver/shell.py", line 60, in sh
10.16 return dry(command, runpipe)
10.16 File "/openedx/venv/lib/python3.8/site-packages/paver/easy.py", line 15, in dry
10.16 return func(*args, **kw)
10.16 File "/openedx/venv/lib/python3.8/site-packages/paver/shell.py", line 55, in runpipe
10.16 raise BuildFailure("Subprocess return code: %d" % p.returncode)
10.16 paver.tasks.BuildFailure: Subprocess return code: 1
After this, I removed the translation soft link, created a new directory with the same name, and put the contents of locale inside it and the build worked like a charm. My guess is the soft link is not mounted @kdmccormick you've worked with mounts before. any idea?
The text was updated successfully, but these errors were encountered:
DawoudSheraz
added
bug
Bugs will be investigated and fixed as quickly as possible.
and removed
bug
Bugs will be investigated and fixed as quickly as possible.
labels
Jan 6, 2025
@CodeWithEmad Thanks for the detailed report. I believe that collectstatic tries to recursively descend each installed packages' staticfiles directories in search of collectable assets. Docker cannot follow symlinks that point outside the build context. So, it makes sense that removing the translations symlink would fix the build. Do you have a recommended fix?
You're absolutely right, dear @kdmccormick.
I think this symlink approach is a common pattern across all XBlocks (Not sure). Generally, I don't think it's a tutor's bug but I think we need to provide some sort of Warning (using a filter maybe) that symlinks will break the build process.
Is there a reason that XBlocks have both local and translations? Can't we just have a translations directory with config.yaml and PO files?
As a part of updating XBlock documentation, I created a simple xblock using edx-cookiecutters with a
--no-input
flag to test the xblock installation. Mounted the xblock usingtutor mounts add /home/emad/Desktop/my-xblock
, and checked the mounted path:I collected strings and compiled messages
Here is my local directory
And a translation directory is linked to this directory.
After I run
tutor images build opened-dev
, following error will raise:After this, I removed the
translation
soft link, created a new directory with the same name, and put the contents oflocale
inside it and the build worked like a charm. My guess is the soft link is not mounted@kdmccormick you've worked with mounts before. any idea?
The text was updated successfully, but these errors were encountered: