Skip to content

Make SharedDataMiddleware respect order of exports#1197

Closed
snoack wants to merge 0 commit intopallets:masterfrom
snoack:master
Closed

Make SharedDataMiddleware respect order of exports#1197
snoack wants to merge 0 commit intopallets:masterfrom
snoack:master

Conversation

@snoack
Copy link
Copy Markdown
Contributor

@snoack snoack commented Nov 19, 2017

The SharedDataMiddleware (and serving.run_simple(static_files=...) respectively) takes a dict, mapping file and directory names in the URL to files, directories or modules on disk. However, there are no dict-lookups involved in that logic, but instead dict item's are iterated, until a first match is found. But since dict items are retrieved in arbitrary order, the behavior is unpredictable, in scenarios like this:

serving.run_simple(static_files={
  '/static/': static_files_dir,
  '/': os.path.join(static_files_dir, 'index.html')
})

If the key / is yielded first, all requests resolve to index.html. Even using an OrderedDict doesn't help, since the SharedDataMiddleware internally creates another dict.

It seems to make most sense to just use lists, both to be passed in when using the API, and for the internal data structure. However, for backwards compatibility I keep supporting dict-like objects as well, in this PR.

@davidism
Copy link
Copy Markdown
Member

Would you rebase against master? We fixed the tests.

@davidism davidism closed this Dec 4, 2017
@davidism
Copy link
Copy Markdown
Member

davidism commented Dec 4, 2017

Wait, what happened? I rebased and pushed to your branch and it wiped all the changes and closed it. There's no option to reopen.

@davidism
Copy link
Copy Markdown
Member

davidism commented Dec 4, 2017

OK, sorry, I messed up and pushed the rebase without your changes, and GitHub won't let me push again because it thinks the pr is closed(?). I'll make a new PR with your commits.

@davidism
Copy link
Copy Markdown
Member

davidism commented Dec 4, 2017

Might be related to having the commits on master instead of a separate branch.

@davidism davidism added this to the 0.13 milestone Dec 5, 2017
@github-actions github-actions bot locked as resolved and limited conversation to collaborators Nov 13, 2020
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants