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)