Browse Source

[MIG] web_notify: Migration to 11.0

- Use the 'session' class of the JS Framework (session no lounger bound
to web client)
- Test change: compare emitted & received messages based on content, not
order. Using string comparison raises false positives.
pull/911/merge
Damien Bouvy 7 years ago
committed by Jairo Llopis
parent
commit
c1765f97c3
  1. 3
      web_notify/__manifest__.py
  2. 1
      web_notify/models/res_users.py
  3. 16
      web_notify/static/src/js/web_client.js
  4. 18
      web_notify/tests/test_res_users.py
  5. 2
      web_notify/views/web_notify.xml

3
web_notify/__manifest__.py

@ -1,4 +1,3 @@
# -*- coding: utf-8 -*-
# Copyright 2016 ACSONE SA/NV # Copyright 2016 ACSONE SA/NV
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
@ -6,7 +5,7 @@
'name': 'Web Notify', 'name': 'Web Notify',
'summary': """ 'summary': """
Send notification messages to user""", Send notification messages to user""",
'version': '10.0.1.0.0',
'version': '11.0.1.0.0',
'description': 'Web Notify', 'description': 'Web Notify',
'license': 'AGPL-3', 'license': 'AGPL-3',
'author': 'ACSONE SA/NV,Odoo Community Association (OCA)', 'author': 'ACSONE SA/NV,Odoo Community Association (OCA)',

1
web_notify/models/res_users.py

@ -1,4 +1,3 @@
# -*- coding: utf-8 -*-
# Copyright 2016 ACSONE SA/NV # Copyright 2016 ACSONE SA/NV
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).

16
web_notify/static/src/js/web_client.js

@ -3,24 +3,18 @@ odoo.define('web_notify.WebClient', function (require) {
var WebClient = require('web.WebClient'); var WebClient = require('web.WebClient');
var base_bus = require('bus.bus'); var base_bus = require('bus.bus');
var session = require('web.session');
WebClient.include({ WebClient.include({
init: function(parent, client_options){
this._super(parent, client_options);
},
show_application: function() { show_application: function() {
var res = this._super(); var res = this._super();
this.start_polling(); this.start_polling();
return res return res
}, },
on_logout: function() {
var self = this;
base_bus.bus.off('notification', this, this.bus_notification);
this._super();
},
start_polling: function() { start_polling: function() {
this.channel_warning = 'notify_warning_' + this.session.uid;
this.channel_info = 'notify_info_' + this.session.uid;
this.channel_warning = 'notify_warning_' + session.uid;
this.channel_info = 'notify_info_' + session.uid;
base_bus.bus.add_channel(this.channel_warning); base_bus.bus.add_channel(this.channel_warning);
base_bus.bus.add_channel(this.channel_info); base_bus.bus.add_channel(this.channel_info);
base_bus.bus.on('notification', this, this.bus_notification); base_bus.bus.on('notification', this, this.bus_notification);
@ -33,7 +27,7 @@ WebClient.include({
var message = notification[1]; var message = notification[1];
if (channel === self.channel_warning) { if (channel === self.channel_warning) {
self.on_message_warning(message); self.on_message_warning(message);
} else if (channel == self.channel_info) {
} else if (channel === self.channel_info) {
self.on_message_info(message); self.on_message_info(message);
} }
}); });

18
web_notify/tests/test_res_users.py

@ -1,9 +1,9 @@
# -*- coding: utf-8 -*-
# Copyright 2016 ACSONE SA/NV # Copyright 2016 ACSONE SA/NV
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
from odoo.tests import common from odoo.tests import common
from odoo.addons.bus.models.bus import json_dump from odoo.addons.bus.models.bus import json_dump
import json
import mock import mock
@ -16,13 +16,11 @@ class TestResUsers(common.TransactionCase):
json_dump(self.env.user.notify_info_channel_name)) json_dump(self.env.user.notify_info_channel_name))
] ]
existing = bus_bus.search(domain) existing = bus_bus.search(domain)
self.env.user.notify_info(
message='message', title='title', sticky=True)
test_msg = {'message': 'message', 'title': 'title', 'sticky': True}
self.env.user.notify_info(**test_msg)
news = bus_bus.search(domain) - existing news = bus_bus.search(domain) - existing
self.assertEqual(1, len(news)) self.assertEqual(1, len(news))
self.assertEqual(
'{"message":"message","sticky":true,"title":"title"}',
news.message)
self.assertEqual(test_msg, json.loads(news.message))
def test_notify_warning(self): def test_notify_warning(self):
bus_bus = self.env['bus.bus'] bus_bus = self.env['bus.bus']
@ -31,13 +29,11 @@ class TestResUsers(common.TransactionCase):
json_dump(self.env.user.notify_warning_channel_name)) json_dump(self.env.user.notify_warning_channel_name))
] ]
existing = bus_bus.search(domain) existing = bus_bus.search(domain)
self.env.user.notify_warning(
message='message', title='title', sticky=True)
test_msg = {'message': 'message', 'title': 'title', 'sticky': True}
self.env.user.notify_warning(**test_msg)
news = bus_bus.search(domain) - existing news = bus_bus.search(domain) - existing
self.assertEqual(1, len(news)) self.assertEqual(1, len(news))
self.assertEqual(
'{"message":"message","sticky":true,"title":"title"}',
news.message)
self.assertEqual(test_msg, json.loads(news.message))
def test_notify_many(self): def test_notify_many(self):
# check that the notification of a list of users is done with # check that the notification of a list of users is done with

2
web_notify/views/web_notify.xml

@ -1,7 +1,7 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<odoo> <odoo>
<data> <data>
<template id="assets_backend" name="web_noify assets" inherit_id="web.assets_backend">
<template id="assets_backend" name="web_notify assets" inherit_id="web.assets_backend">
<xpath expr="." position="inside"> <xpath expr="." position="inside">
<script type="text/javascript" src="/web_notify/static/src/js/web_client.js"/> <script type="text/javascript" src="/web_notify/static/src/js/web_client.js"/>
</xpath> </xpath>

Loading…
Cancel
Save