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

Feature/80 new upload widget #83

Open
wants to merge 45 commits into
base: master
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
45 commits
Select commit Hold shift + click to select a range
1c984dd
Add new action to infer a tabular resource schema
aivuk Dec 6, 2022
154d529
Update ckanext/validation/logic.py
aivuk Dec 6, 2022
3b1773c
Remove coverage report
aivuk Dec 6, 2022
a167acb
Merge branch 'feature/76-add-resource-table-schema-infer' of github.c…
aivuk Dec 6, 2022
670d896
correct toolkit imported name
aivuk Dec 6, 2022
1dd1a8a
use new action endpoint with upload widget to create a resource
aivuk Dec 9, 2022
0f45263
remove default resource upload file field
aivuk Dec 10, 2022
124a0f7
Update widget and logic to replace already existing resource files
aivuk Dec 12, 2022
f2af792
Pass the url_type parameter to the ckan-uploader component
aivuk Dec 13, 2022
52ca754
get variables from resource form from hidden inputs
aivuk Dec 13, 2022
e8b5b42
add ckan_uploader snippet
aivuk Dec 13, 2022
6c167a6
Update logic to add another resource after saving one
aivuk Dec 14, 2022
a3c6e27
Add some comments to ckan-uploader-module
aivuk Dec 14, 2022
a225742
Corrects behaviour for uploaded file is not tabular
aivuk Dec 15, 2022
0644e0a
use custom resource_create and resource_update instead of new actions…
aivuk Dec 15, 2022
4c61a0b
remove check for content_length in uploaded resource schema file
aivuk Dec 16, 2022
6ece563
Remove unused actions
amercader Dec 16, 2022
61ff6d4
Use helper to get package id from url
aivuk Jan 12, 2023
d744d2f
Import ckan.model on helpers
aivuk Jan 12, 2023
9c16f8f
Fix blueprints missing imports
aivuk Jan 12, 2023
fb8f7f7
add resource edit new endpoint
aivuk Jan 30, 2023
28eec48
Create resource update endpoint and update ckan-uploader widget
aivuk Feb 1, 2023
547c5ac
Correct default return values for helpers
aivuk Feb 1, 2023
5fb0ec0
Get initialization variables for ckan-uploade its template.
aivuk Feb 1, 2023
8ac15f1
Remove custom resource_form.html template.
aivuk Feb 1, 2023
bfd400a
Get the schema from the returned schema from the action
aivuk Feb 1, 2023
036262e
Stop infering the schema as default in resource create and update
aivuk Feb 1, 2023
25e39ad
Add helpers that are used by ckan_uploader.html template
aivuk Feb 1, 2023
93e1956
Fix template for ckan_uploader adding correctly the variables intial …
aivuk Feb 1, 2023
431beeb
shorter form to compare schema_url value
aivuk Feb 6, 2023
63d8bcd
add logic to switch between file upload and resource url
aivuk Feb 8, 2023
930bb35
Merge branch 'feature/80-new-upload-widget' of github.com:frictionles…
aivuk Feb 8, 2023
a9e5459
remove erroneous test for schema file uploaded size
aivuk Feb 8, 2023
56ab8bb
Remove scrolling to schema json on resource edit
aivuk Feb 8, 2023
ebcc71a
Add basic create/update tests
amercader Feb 23, 2023
78a3351
Bump frictionless to fix schema infer errors
amercader Feb 23, 2023
25dbed6
Revert accidental changes in ckan-uploader.js
amercader Feb 23, 2023
95f31e4
Revert changes made to resource_create / resource_update actions
amercader Feb 23, 2023
9cbb754
Add turn_off_validation context manager
amercader Feb 23, 2023
d9598c5
Don't run validations when creating the draft resource
amercader Feb 23, 2023
3af20e2
Specify format in tests because of ckan/ckan#7415
amercader Feb 23, 2023
9236615
Remove duplicated test
amercader Feb 28, 2023
0198797
Bump responses
amercader Feb 28, 2023
d0f780d
Revert file size check removal in a9e5459
amercader Mar 29, 2023
f990969
Remove debugger
amercader Mar 29, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Add turn_off_validation context manager
Rather than try to deal with complex logic on the plugin hooks with
dodgy context keys, it offers a way to shut down completely the
validation process in a specific block of code. Works by explicitly
setting all the validation config options to False and restoring the
previous values afterwards.
amercader committed Feb 23, 2023
commit 9cbb7546aa2917c42f9815fffa6cae8f20059b10
74 changes: 74 additions & 0 deletions ckanext/validation/tests/test_utils.py
Original file line number Diff line number Diff line change
@@ -2,6 +2,10 @@
import uuid
from unittest import mock

from ckantoolkit import config

from ckantoolkit.tests.factories import Resource

import pytest
from pyfakefs import fake_filesystem_unittest

@@ -11,6 +15,7 @@
get_update_mode_from_config,
get_local_upload_path,
delete_local_uploaded_file,
turn_off_validation,
)


@@ -68,6 +73,75 @@ def test_config_both_false(self):
assert get_create_mode_from_config() is None


@pytest.mark.usefixtures("clean_db", "validation_setup", "mock_uploads")
class TestTurnOffValidation(object):

@pytest.mark.ckan_config("ckanext.validation.run_on_update_async", True)
@pytest.mark.ckan_config("ckanext.validation.run_on_create_async", True)
def test_turn_off_async(self):
assert config["ckanext.validation.run_on_update_async"] is True
assert config["ckanext.validation.run_on_create_async"] is True

with turn_off_validation():
assert config["ckanext.validation.run_on_update_async"] is False
assert config["ckanext.validation.run_on_create_async"] is False

with mock.patch("ckanext.validation.plugin._run_async_validation") as mock_validate:

Resource()

assert not mock_validate.called

assert config["ckanext.validation.run_on_update_async"] is True
assert config["ckanext.validation.run_on_create_async"] is True

@pytest.mark.ckan_config("ckanext.validation.run_on_update_sync", True)
@pytest.mark.ckan_config("ckanext.validation.run_on_create_sync", True)
def test_turn_off_sync(self):
assert config["ckanext.validation.run_on_update_sync"] is True
assert config["ckanext.validation.run_on_create_sync"] is True

with turn_off_validation():
assert config["ckanext.validation.run_on_update_sync"] is False
assert config["ckanext.validation.run_on_create_sync"] is False

with mock.patch("ckanext.validation.logic._run_sync_validation") as mock_validate:

Resource()

assert not mock_validate.called

assert config["ckanext.validation.run_on_update_sync"] is True
assert config["ckanext.validation.run_on_create_sync"] is True


@pytest.mark.ckan_config("ckanext.validation.run_on_update_async", False)
@pytest.mark.ckan_config("ckanext.validation.run_on_create_sync", True)
@pytest.mark.ckan_config("ckanext.validation.run_on_update_sync", False)
def test_turn_off_preserves_values(self):
assert config["ckanext.validation.run_on_update_async"] is False
assert "ckanext.validation.run_on_create_async" not in config
assert config["ckanext.validation.run_on_create_sync"] is True
assert config["ckanext.validation.run_on_update_sync"] is False

with turn_off_validation():
assert config["ckanext.validation.run_on_update_async"] is False
assert config["ckanext.validation.run_on_create_async"] is False
assert config["ckanext.validation.run_on_update_sync"] is False
assert config["ckanext.validation.run_on_create_sync"] is False

with mock.patch("ckanext.validation.logic._run_sync_validation") as mock_validate:

Resource()

assert not mock_validate.called

assert config["ckanext.validation.run_on_update_async"] is False
assert "ckanext.validation.run_on_create_async" not in config
assert config["ckanext.validation.run_on_create_sync"] is True
assert config["ckanext.validation.run_on_update_sync"] is False


class TestFiles(object):
@mock_uploads_fake_fs
def test_local_path(self, mock_open):
30 changes: 30 additions & 0 deletions ckanext/validation/utils.py
Original file line number Diff line number Diff line change
@@ -1,13 +1,43 @@
import os
import logging

from contextlib import contextmanager

from ckan.lib.uploader import ResourceUpload
from ckantoolkit import config, asbool


log = logging.getLogger(__name__)


@contextmanager
def turn_off_validation():

keys = (
'ckanext.validation.run_on_update_sync',
'ckanext.validation.run_on_update_async',
'ckanext.validation.run_on_create_sync',
'ckanext.validation.run_on_create_async',
)

# Store current state
current = {}
for key in keys:
current[key] = config.get(key)

# Turn off all validation
for key in keys:
config[key] = False

yield

# Restore state
for key in keys:
config.pop(key, None)
if current[key] is not None:
config[key] = current[key]


def get_update_mode_from_config():
if asbool(
config.get(u'ckanext.validation.run_on_update_sync', False)):