mirror of
https://github.com/paperless-ngx/paperless-ngx.git
synced 2025-04-02 13:45:10 -05:00
force flush on temp file during consumption
file.write() does not guarantee that a file handle contains anything without calling an accompanying file.flush() For typical files that are larger than the OS-file buffer, this is no problem For small files (e.g. 64 characters in a .TXT), this race condition leads to `inode/x-empty` because the file inode is created, but no content is written to it
This commit is contained in:
parent
29ce2515ee
commit
21c501de28
@ -29,9 +29,9 @@
|
|||||||
document:
|
document:
|
||||||
content: "{{ content }}"
|
content: "{{ content }}"
|
||||||
filename: "{{ filename }}.txt"
|
filename: "{{ filename }}.txt"
|
||||||
mime_type: text/plain
|
|
||||||
headers:
|
headers:
|
||||||
Authorization: 'Basic {{ (paperlessng_superuser_name + ":" + paperlessng_superuser_password) | b64encode }}'
|
Authorization: 'Basic {{ (paperlessng_superuser_name + ":" + paperlessng_superuser_password) | b64encode }}'
|
||||||
|
Content-Type: text/plain
|
||||||
return_content: yes
|
return_content: yes
|
||||||
register: post_document
|
register: post_document
|
||||||
failed_when: "'OK' not in post_document.content"
|
failed_when: "'OK' not in post_document.content"
|
||||||
@ -45,10 +45,6 @@
|
|||||||
register: logs
|
register: logs
|
||||||
failed_when: "('Consuming ' + filename + '.txt') not in logs.content"
|
failed_when: "('Consuming ' + filename + '.txt') not in logs.content"
|
||||||
|
|
||||||
- name: sleep 5 seconds
|
|
||||||
pause:
|
|
||||||
seconds: 5
|
|
||||||
|
|
||||||
- name: verify uploaded document has been consumed
|
- name: verify uploaded document has been consumed
|
||||||
uri:
|
uri:
|
||||||
url: "http://{{ paperlessng_listen_address }}:{{ paperlessng_listen_port }}/api/logs/"
|
url: "http://{{ paperlessng_listen_address }}:{{ paperlessng_listen_port }}/api/logs/"
|
||||||
|
@ -383,6 +383,7 @@ class PostDocumentView(APIView):
|
|||||||
dir=settings.SCRATCH_DIR,
|
dir=settings.SCRATCH_DIR,
|
||||||
delete=False) as f:
|
delete=False) as f:
|
||||||
f.write(doc_data)
|
f.write(doc_data)
|
||||||
|
f.flush()
|
||||||
os.utime(f.name, times=(t, t))
|
os.utime(f.name, times=(t, t))
|
||||||
|
|
||||||
async_task("documents.tasks.consume_file",
|
async_task("documents.tasks.consume_file",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user