Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix build command on Windows #158

Open
danizen opened this issue Feb 28, 2022 · 6 comments
Open

Fix build command on Windows #158

danizen opened this issue Feb 28, 2022 · 6 comments

Comments

@danizen
Copy link

danizen commented Feb 28, 2022

DESIRED BEHAVIOR

My team uses django-bakery in a couple of places. We want builds on Windows to just work without workarounds.
However, right now we need some workarounds because of limitations that prevent builds on Windows.

WORKAROUND

In my environment so far, two changes are needed to allow builds on Windows to proceed.

First, make sure the BUILD_DIR is free of a colon, which fails validation by python-fs:

__build_dir = os.environ.get('BUILD_DIR', os.path.join(BASE_DIR, 'build'))
if sys.platform == 'win32':
    __build_dir = __build_dir.replace('\\', '/')[2:]
BUILD_DIR = __build_dir

Second, override the build method of BuildableTemplateView to correct for the use of os.path.join:

from bakery.views import BuildableTemplateView as BaseBuildableTemplateView


class BuildableTemplateView(BaseBuildableTemplateView):
    def build(self):
        logger.debug("Building %s" % self.template_name)
        build_path = self.get_build_path()
        self.request = self.create_request(build_path)
        path = fs.path.combine(settings.BUILD_DIR, build_path)
        self.prep_directory(build_path)
        self.build_file(path, self.get_content())

SHORT-TERM FIX

A short-term fix is to simply promote at least the 1-line change to build into the package. 3 lines in the local or development settings file is acceptably dry. I'll admit that our work-around for the BUILD_DIR is not a complete solution - you need the drive specification on Windows.

I will work on a pull request for the short-term fix, but I think there will need to be discussion around the longer term fix.

LONG-TERM FIX

Using python-fs is really not that great now that Python 3 supports the pathlib module. It might be possible to migrate to the pathlib module.

@palewire
Copy link
Owner

palewire commented Feb 28, 2022

I'm okay with hammering out a short term fix to get it working for you. I am open to deprecating python-fs in favor of pathlib.

@danizen
Copy link
Author

danizen commented Feb 28, 2022

I just did a "python setup.py test", and it looks like some requirements would need to be pinned for me to test successfully. Some of these are in test code, and so pinning Django==2.2 might be acceptable to deal with this for now. I may need to do more changes than I expected.

@danizen
Copy link
Author

danizen commented Feb 28, 2022

Is a live bucket required to run tests? Can that be easily parameterized?

@palewire
Copy link
Owner

palewire commented Feb 28, 2022

It's been a good while since I worked through these details, but I'm pretty sure Travis pulls it off with a mock.

https://github.com/palewire/django-bakery/blob/master/.travis.yml#L13-L49

@danizen
Copy link
Author

danizen commented Feb 28, 2022

I see. The intention is to define AWS_ACCESS_KEY_ID and so on to make sure that we are not mutating any real environment, as described in moto documentation.

The issue is resolved for me with small changes to the tests, I think deriving from changes in how the moto API works - it patches now on client or resource creation I think. The boto API has also changed a little and I also had to use kwargs only in a couple of places in tests. Might not have needed to do if I got the mocking right first.

danizen@4b655d8

I am testing now only with Django 2.2, but I saw there were some issues with Django 4. I will give more recent versions of Django a try tomorrow.

@danizen
Copy link
Author

danizen commented Mar 1, 2022

I have tested with Django 3.2 and added it to the build matrix. I am stopped from a good pull request by two things:

  • Travis-CI.org shutdown awhile ago, and so I would have to go through a lot to test that Python 2.7 still works. Dropping support for Python 2.7 and Django 1.11 would make me confident - without them I would want a build bot.

  • A better fix would not require a work-around on Windows for BUILD_DIR setting. So, I want to understand an OSFS is supposed to work on Windows. My intuition is that the BUILD_ROOT should be validated with os.path and then opened as a filesystem itself, and the relative path is what should be validated. However, I am not certain and want to wait for Question - how to interact with Windows OSFS paths? PyFilesystem/pyfilesystem2#526

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants