61e1e04132
Per default, a document opened by a user action will always open in a new frame. For tdf#83722, this behaviour was extended to documents created from templates. But this currently also affects the default factory templates, if these are replaced by a config setting with a real template, which was not intentional. So this patch introduces a new MediaDescriptor property, which allows to mark a document as replaceable and automatically sets it for factory default documents. If this property is set to true, a document just acts as a placeholder while it's unmodified. I.e. the next opened document from its frame will close and replace it. Change-Id: I45ffa8709f7cdda949fac78f3b363f120f0c4a03 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/88257 Tested-by: Jenkins Reviewed-by: Thorsten Behrens <Thorsten.Behrens@CIB.de>
71 lines
2.3 KiB
Python
71 lines
2.3 KiB
Python
#! /usr/bin/env python
|
|
# -*- tab-width: 4; indent-tabs-mode: nil; py-indent-offset: 4 -*-
|
|
#
|
|
# This file is part of the LibreOffice project.
|
|
#
|
|
# This Source Code Form is subject to the terms of the Mozilla Public
|
|
# License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
#
|
|
import unittest
|
|
import unohelper
|
|
from org.libreoffice.unotest import UnoInProcess
|
|
from com.sun.star.lang import IllegalArgumentException
|
|
from com.sun.star.beans import PropertyValue
|
|
import uno
|
|
|
|
|
|
class TestXModel(unittest.TestCase):
|
|
|
|
@classmethod
|
|
def setUpClass(cls):
|
|
cls._uno = UnoInProcess()
|
|
cls._uno.setUp()
|
|
|
|
@classmethod
|
|
def tearDownClass(cls):
|
|
cls._uno.tearDown()
|
|
|
|
def test_setArgs_valid(self):
|
|
xDoc = self._uno.openEmptyWriterDoc()
|
|
self.assertIsNotNone(xDoc)
|
|
|
|
p1 = PropertyValue(Name="SuggestedSaveAsName", Value="prettyFileName")
|
|
p2 = PropertyValue(Name="SuggestedSaveAsDir", Value="/my/dir")
|
|
p3 = PropertyValue(Name="LockContentExtraction", Value=True)
|
|
p4 = PropertyValue(Name="LockExport", Value=True)
|
|
p5 = PropertyValue(Name="LockPrint", Value=True)
|
|
p6 = PropertyValue(Name="LockSave", Value=True)
|
|
p7 = PropertyValue(Name="LockEditDoc", Value=True)
|
|
p8 = PropertyValue(Name="Replaceable", Value=True)
|
|
xDoc.setArgs([p1, p2, p3, p4, p5, p6, p7, p8])
|
|
|
|
# Make sure that all properties are returned with getArgs()
|
|
args = xDoc.getArgs()
|
|
self.assertTrue(p1 in args)
|
|
self.assertTrue(p2 in args)
|
|
self.assertTrue(p3 in args)
|
|
self.assertTrue(p4 in args)
|
|
self.assertTrue(p5 in args)
|
|
self.assertTrue(p6 in args)
|
|
self.assertTrue(p7 in args)
|
|
self.assertTrue(p8 in args)
|
|
|
|
xDoc.close(True)
|
|
|
|
def test_setArgs_invalid(self):
|
|
xDoc = self._uno.openEmptyWriterDoc()
|
|
self.assertIsNotNone(xDoc)
|
|
|
|
# IllegalArgumentException should be thrown when setting a non-existing property
|
|
p1 = PropertyValue(Name="PropertyNotExists", Value="doesntmatter")
|
|
with self.assertRaises(IllegalArgumentException):
|
|
xDoc.setArgs([p1])
|
|
|
|
xDoc.close(True)
|
|
|
|
|
|
if __name__ == '__main__':
|
|
unittest.main()
|
|
|
|
# vim: set shiftwidth=4 softtabstop=4 expandtab:
|