mirror of
https://github.com/bringout/oca-ocb-report.git
synced 2026-04-21 15:02:01 +02:00
103 lines
4.6 KiB
Python
103 lines
4.6 KiB
Python
import json
|
|
import base64
|
|
|
|
from odoo.tests.common import HttpCase, new_test_user
|
|
from odoo.tools import mute_logger
|
|
|
|
from .common import DashboardTestCommon
|
|
|
|
class TestShareController(DashboardTestCommon, HttpCase):
|
|
|
|
@classmethod
|
|
@mute_logger('odoo.tests', 'odoo.addons.auth_signup.models.res_users')
|
|
def setUpClass(cls):
|
|
super().setUpClass()
|
|
cls.alex = new_test_user(cls.env, login='AlexPort', groups='base.group_user,base.group_allow_export')
|
|
|
|
def test_dashboard_share_portal(self):
|
|
dashboard = self.create_dashboard()
|
|
share = self.share_dashboard(dashboard)
|
|
response = self.url_open(f"/dashboard/share/{share.id}/{share.access_token}")
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
def test_dashboard_share_portal_wrong_token(self):
|
|
dashboard = self.create_dashboard()
|
|
share = self.share_dashboard(dashboard)
|
|
with mute_logger('odoo.http'):
|
|
response = self.url_open(f"/dashboard/share/{share.id}/a-random-token")
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_public_dashboard_data(self):
|
|
dashboard = self.create_dashboard()
|
|
share = self.share_dashboard(dashboard)
|
|
response = self.url_open(f"/dashboard/data/{share.id}/{share.access_token}")
|
|
self.assertEqual(response.status_code, 200)
|
|
self.assertEqual(response.json(), json.loads(dashboard.spreadsheet_data))
|
|
|
|
def test_public_dashboard_data_wrong_token(self):
|
|
dashboard = self.create_dashboard()
|
|
share = self.share_dashboard(dashboard)
|
|
with mute_logger('odoo.http'): # mute 403 warning
|
|
response = self.url_open(f"/dashboard/data/{share.id}/a-random-token")
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_public_dashboard_revoked_access(self):
|
|
dashboard = self.create_dashboard()
|
|
with self.with_user(self.user.login):
|
|
share = self.share_dashboard(dashboard)
|
|
|
|
response = self.url_open(f"/dashboard/data/{share.id}/{share.access_token}")
|
|
self.assertEqual(response.status_code, 200) # access granted
|
|
|
|
self.user.group_ids -= self.group # revoke access
|
|
|
|
with mute_logger('odoo.http'): # mute 403 warning
|
|
response = self.url_open(f"/dashboard/data/{share.id}/{share.access_token}")
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_download_dashboard(self):
|
|
dashboard = self.create_dashboard()
|
|
share = self.share_dashboard(dashboard)
|
|
share.excel_export = base64.b64encode(b"test")
|
|
self.authenticate('AlexPort', 'AlexPort')
|
|
response = self.url_open(f"/dashboard/download/{share.id}/{share.access_token}")
|
|
self.assertEqual(response.status_code, 200)
|
|
self.assertEqual(response.content, b"test")
|
|
|
|
def test_download_dashboard_no_export(self):
|
|
dashboard = self.create_dashboard()
|
|
share = self.share_dashboard(dashboard)
|
|
share.excel_export = base64.b64encode(b"test")
|
|
self.authenticate('AlexPort', 'AlexPort')
|
|
response = self.url_open(f"/dashboard/download/{share.id}/{share.access_token}")
|
|
self.assertEqual(response.status_code, 200)
|
|
self.assertEqual(response.content, b"test")
|
|
|
|
self.alex.group_ids -= self.env.ref('base.group_allow_export', raise_if_not_found=False) # revoke export right
|
|
with mute_logger('odoo.http'): # mute 400 warning
|
|
response = self.url_open(f"/dashboard/download/{share.id}/{share.access_token}")
|
|
self.assertEqual(response.status_code, 422)
|
|
|
|
def test_download_dashboard_wrong_token(self):
|
|
dashboard = self.create_dashboard()
|
|
share = self.share_dashboard(dashboard)
|
|
share.excel_export = base64.b64encode(b"test")
|
|
self.authenticate('AlexPort', 'AlexPort')
|
|
with mute_logger('odoo.http'): # mute 403 warning
|
|
response = self.url_open(f"/dashboard/download/{share.id}/a-random-token")
|
|
self.assertEqual(response.status_code, 403)
|
|
|
|
def test_download_dashboard_revoked_access(self):
|
|
dashboard = self.create_dashboard()
|
|
self.authenticate('AlexPort', 'AlexPort')
|
|
with self.with_user(self.user.login):
|
|
share = self.share_dashboard(dashboard)
|
|
share.excel_export = base64.b64encode(b"test")
|
|
response = self.url_open(f"/dashboard/download/{share.id}/{share.access_token}")
|
|
self.assertEqual(response.status_code, 200) # access granted
|
|
|
|
self.user.group_ids -= self.group # revoke access
|
|
|
|
with mute_logger('odoo.http'): # mute 403 warning
|
|
response = self.url_open(f"/dashboard/download/{share.id}/{share.access_token}")
|
|
self.assertEqual(response.status_code, 403)
|