@openui5/sap.ui.core 1.118.0 → 1.119.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintrc.json +9 -0
- package/THIRDPARTY.txt +2 -2
- package/package.json +1 -1
- package/src/jquery.sap.global.js +1 -1
- package/src/jquery.sap.properties.js +1 -1
- package/src/jquery.sap.resources.js +1 -1
- package/src/jquery.sap.script.js +1 -1
- package/src/jquery.sap.storage.js +3 -3
- package/src/sap/base/Event.js +1 -1
- package/src/sap/base/Eventing.js +1 -1
- package/src/sap/base/config.js +1 -1
- package/src/sap/base/i18n/LanguageTag.js +1 -1
- package/src/sap/base/i18n/Localization.js +16 -1
- package/src/sap/base/i18n/ResourceBundle.js +5 -0
- package/src/sap/base/i18n/date/TimezoneUtils.js +1 -1
- package/src/sap/base/util/UriParameters.js +26 -19
- package/src/sap/base/util/restricted/_CancelablePromise.js +1 -1
- package/src/sap/base/util/restricted/_castArray.js +1 -1
- package/src/sap/base/util/restricted/_compact.js +1 -1
- package/src/sap/base/util/restricted/_curry.js +1 -1
- package/src/sap/base/util/restricted/_debounce.js +1 -1
- package/src/sap/base/util/restricted/_difference.js +1 -1
- package/src/sap/base/util/restricted/_differenceBy.js +1 -1
- package/src/sap/base/util/restricted/_differenceWith.js +1 -1
- package/src/sap/base/util/restricted/_flatMap.js +1 -1
- package/src/sap/base/util/restricted/_flatMapDeep.js +1 -1
- package/src/sap/base/util/restricted/_flatMapDepth.js +1 -1
- package/src/sap/base/util/restricted/_flatten.js +1 -1
- package/src/sap/base/util/restricted/_flattenDeep.js +1 -1
- package/src/sap/base/util/restricted/_flattenDepth.js +1 -1
- package/src/sap/base/util/restricted/_intersection.js +1 -1
- package/src/sap/base/util/restricted/_intersectionBy.js +1 -1
- package/src/sap/base/util/restricted/_intersectionWith.js +1 -1
- package/src/sap/base/util/restricted/_isEqual.js +1 -1
- package/src/sap/base/util/restricted/_isEqualWith.js +1 -1
- package/src/sap/base/util/restricted/_isNil.js +1 -1
- package/src/sap/base/util/restricted/_max.js +1 -1
- package/src/sap/base/util/restricted/_merge.js +1 -1
- package/src/sap/base/util/restricted/_mergeWith.js +1 -1
- package/src/sap/base/util/restricted/_min.js +1 -1
- package/src/sap/base/util/restricted/_omit.js +1 -1
- package/src/sap/base/util/restricted/_pick.js +1 -1
- package/src/sap/base/util/restricted/_pickBy.js +1 -1
- package/src/sap/base/util/restricted/_throttle.js +1 -1
- package/src/sap/base/util/restricted/_toArray.js +1 -1
- package/src/sap/base/util/restricted/_union.js +1 -1
- package/src/sap/base/util/restricted/_unionBy.js +1 -1
- package/src/sap/base/util/restricted/_unionWith.js +1 -1
- package/src/sap/base/util/restricted/_uniq.js +1 -1
- package/src/sap/base/util/restricted/_uniqBy.js +1 -1
- package/src/sap/base/util/restricted/_uniqWith.js +1 -1
- package/src/sap/base/util/restricted/_without.js +1 -1
- package/src/sap/base/util/restricted/_xor.js +1 -1
- package/src/sap/base/util/restricted/_xorBy.js +1 -1
- package/src/sap/base/util/restricted/_xorWith.js +1 -1
- package/src/sap/base/util/restricted/_zipObject.js +1 -1
- package/src/sap/base/util/restricted/_zipObjectDeep.js +1 -1
- package/src/sap/ui/Device.js +3 -3
- package/src/sap/ui/Global.js +4 -4
- package/src/sap/ui/base/BindingInfo.js +25 -3
- package/src/sap/ui/base/Event.js +1 -1
- package/src/sap/ui/base/EventProvider.js +1 -1
- package/src/sap/ui/base/Interface.js +1 -1
- package/src/sap/ui/base/ManagedObject.js +2 -2
- package/src/sap/ui/base/ManagedObjectMetadata.js +4 -3
- package/src/sap/ui/base/Metadata.js +3 -3
- package/src/sap/ui/base/Object.js +1 -1
- package/src/sap/ui/base/ObjectPool.js +1 -1
- package/src/sap/ui/core/.library +1 -1
- package/src/sap/ui/core/AccessKeysEnablement.js +2 -2
- package/src/sap/ui/core/BusyIndicator.js +1 -1
- package/src/sap/ui/core/Component.js +68 -51
- package/src/sap/ui/core/ComponentContainer.js +1 -1
- package/src/sap/ui/core/ComponentMetadata.js +1 -1
- package/src/sap/ui/core/ComponentSupport.js +1 -1
- package/src/sap/ui/core/Configuration.js +15 -167
- package/src/sap/ui/core/Control.js +2 -2
- package/src/sap/ui/core/Core.js +162 -93
- package/src/sap/ui/core/CustomData.js +1 -1
- package/src/sap/ui/core/CustomStyleClassSupport.js +3 -3
- package/src/sap/ui/core/DeclarativeSupport.js +1 -1
- package/src/sap/ui/core/Element.js +40 -4
- package/src/sap/ui/core/ElementMetadata.js +1 -1
- package/src/sap/ui/core/EnabledPropagator.js +1 -1
- package/src/sap/ui/core/EventBus.js +19 -2
- package/src/sap/ui/core/FocusHandler.js +3 -24
- package/src/sap/ui/core/Fragment.js +2 -2
- package/src/sap/ui/core/HTML.js +1 -1
- package/src/sap/ui/core/History.js +1 -1
- package/src/sap/ui/core/Icon.js +1 -1
- package/src/sap/ui/core/IndicationColorSupport.js +1 -1
- package/src/sap/ui/core/IntervalTrigger.js +1 -1
- package/src/sap/ui/core/InvisibleMessage.js +1 -1
- package/src/sap/ui/core/InvisibleRenderer.js +1 -1
- package/src/sap/ui/core/InvisibleText.js +2 -2
- package/src/sap/ui/core/Item.js +1 -1
- package/src/sap/ui/core/LabelEnablement.js +11 -4
- package/src/sap/ui/core/LayoutData.js +1 -1
- package/src/sap/ui/core/Lib.js +42 -42
- package/src/sap/ui/core/ListItem.js +1 -1
- package/src/sap/ui/core/LocalBusyIndicator.js +1 -1
- package/src/sap/ui/core/Locale.js +1 -1
- package/src/sap/ui/core/LocaleData.js +1 -1
- package/src/sap/ui/core/Manifest.js +1 -1
- package/src/sap/ui/core/Message.js +4 -4
- package/src/sap/ui/core/Messaging.js +4 -5
- package/src/sap/ui/core/Popup.js +3 -3
- package/src/sap/ui/core/RenderManager.js +15 -10
- package/src/sap/ui/core/Renderer.js +1 -1
- package/src/sap/ui/core/Rendering.js +1 -0
- package/src/sap/ui/core/ResizeHandler.js +15 -20
- package/src/sap/ui/core/ScrollBar.js +1 -1
- package/src/sap/ui/core/SeparatorItem.js +1 -1
- package/src/sap/ui/core/ShortcutHintsMixin.js +5 -5
- package/src/sap/ui/core/StashedControlSupport.js +4 -4
- package/src/sap/ui/core/StaticArea.js +66 -74
- package/src/sap/ui/core/Theming.js +71 -8
- package/src/sap/ui/core/Title.js +1 -1
- package/src/sap/ui/core/TooltipBase.js +1 -1
- package/src/sap/ui/core/UIArea.js +10 -9
- package/src/sap/ui/core/UIComponent.js +2 -2
- package/src/sap/ui/core/UIComponentMetadata.js +1 -1
- package/src/sap/ui/core/ValueStateSupport.js +1 -1
- package/src/sap/ui/core/VariantLayoutData.js +1 -1
- package/src/sap/ui/core/XMLComposite.js +4 -2
- package/src/sap/ui/core/XMLCompositeMetadata.js +1 -1
- package/src/sap/ui/core/_IconRegistry.js +2 -0
- package/src/sap/ui/core/cache/CacheManager.js +22 -16
- package/src/sap/ui/core/cache/LRUPersistentCache.js +13 -7
- package/src/sap/ui/core/date/UI5Date.js +1 -1
- package/src/sap/ui/core/delegate/ItemNavigation.js +3 -3
- package/src/sap/ui/core/delegate/ScrollEnablement.js +1 -1
- package/src/sap/ui/core/dnd/DragDropBase.js +1 -1
- package/src/sap/ui/core/dnd/DragDropInfo.js +6 -6
- package/src/sap/ui/core/dnd/DragInfo.js +4 -4
- package/src/sap/ui/core/dnd/DropInfo.js +6 -6
- package/src/sap/ui/core/format/TimezoneUtil.js +1 -1
- package/src/sap/ui/core/getCompatibilityVersion.js +64 -0
- package/src/sap/ui/core/hyphenation/Hyphenation.js +1 -1
- package/src/sap/ui/core/library.js +14 -9
- package/src/sap/ui/core/message/ControlMessageProcessor.js +4 -4
- package/src/sap/ui/core/message/Message.js +14 -13
- package/src/sap/ui/core/message/MessageManager.js +12 -13
- package/src/sap/ui/core/message/MessageMixin.js +2 -2
- package/src/sap/ui/core/message/MessageParser.js +1 -1
- package/src/sap/ui/core/message/MessageProcessor.js +2 -2
- package/src/sap/ui/core/message/MessageType.js +4 -4
- package/src/sap/ui/core/messagebundle_ar.properties +2 -2
- package/src/sap/ui/core/messagebundle_bg.properties +3 -3
- package/src/sap/ui/core/messagebundle_ca.properties +1 -1
- package/src/sap/ui/core/messagebundle_cs.properties +4 -4
- package/src/sap/ui/core/messagebundle_cy.properties +1 -1
- package/src/sap/ui/core/messagebundle_da.properties +3 -3
- package/src/sap/ui/core/messagebundle_de.properties +2 -2
- package/src/sap/ui/core/messagebundle_el.properties +10 -10
- package/src/sap/ui/core/messagebundle_en.properties +4 -4
- package/src/sap/ui/core/messagebundle_es.properties +17 -17
- package/src/sap/ui/core/messagebundle_fi.properties +1 -1
- package/src/sap/ui/core/messagebundle_fr.properties +21 -21
- package/src/sap/ui/core/messagebundle_hi.properties +2 -2
- package/src/sap/ui/core/messagebundle_hr.properties +6 -6
- package/src/sap/ui/core/messagebundle_hu.properties +10 -10
- package/src/sap/ui/core/messagebundle_id.properties +5 -5
- package/src/sap/ui/core/messagebundle_it.properties +57 -57
- package/src/sap/ui/core/messagebundle_iw.properties +5 -5
- package/src/sap/ui/core/messagebundle_kk.properties +1 -1
- package/src/sap/ui/core/messagebundle_ko.properties +6 -6
- package/src/sap/ui/core/messagebundle_lv.properties +5 -5
- package/src/sap/ui/core/messagebundle_ms.properties +5 -5
- package/src/sap/ui/core/messagebundle_nl.properties +12 -12
- package/src/sap/ui/core/messagebundle_no.properties +8 -8
- package/src/sap/ui/core/messagebundle_pl.properties +2 -2
- package/src/sap/ui/core/messagebundle_pt.properties +8 -8
- package/src/sap/ui/core/messagebundle_ro.properties +2 -2
- package/src/sap/ui/core/messagebundle_ru.properties +7 -7
- package/src/sap/ui/core/messagebundle_sk.properties +2 -2
- package/src/sap/ui/core/messagebundle_sl.properties +9 -9
- package/src/sap/ui/core/messagebundle_sv.properties +8 -8
- package/src/sap/ui/core/messagebundle_th.properties +18 -18
- package/src/sap/ui/core/messagebundle_tr.properties +5 -5
- package/src/sap/ui/core/messagebundle_uk.properties +8 -8
- package/src/sap/ui/core/messagebundle_vi.properties +1 -1
- package/src/sap/ui/core/messagebundle_zh_CN.properties +2 -2
- package/src/sap/ui/core/messagebundle_zh_TW.properties +24 -24
- package/src/sap/ui/core/mvc/HTMLView.js +1 -1
- package/src/sap/ui/core/mvc/JSONView.js +1 -1
- package/src/sap/ui/core/mvc/JSView.js +1 -1
- package/src/sap/ui/core/mvc/TemplateView.js +1 -1
- package/src/sap/ui/core/mvc/View.js +3 -3
- package/src/sap/ui/core/mvc/XMLView.js +1 -1
- package/src/sap/ui/core/plugin/DeclarativeSupport.js +1 -1
- package/src/sap/ui/core/plugin/LessSupport.js +3 -3
- package/src/sap/ui/core/plugin/TemplatingSupport.js +1 -1
- package/src/sap/ui/core/postmessage/Bus.js +1 -1
- package/src/sap/ui/core/postmessage/confirmationDialog.js +1 -1
- package/src/sap/ui/core/routing/async/Target.js +5 -4
- package/src/sap/ui/core/routing/sync/Target.js +3 -3
- package/src/sap/ui/core/rules/App.support.js +30 -1
- package/src/sap/ui/core/rules/Config.support.js +4 -0
- package/src/sap/ui/core/rules/CoreHelper.support.js +3 -3
- package/src/sap/ui/core/rules/Theming.support.js +4 -0
- package/src/sap/ui/core/search/OpenSearchProvider.js +1 -1
- package/src/sap/ui/core/search/SearchProvider.js +1 -1
- package/src/sap/ui/core/service/Service.js +1 -1
- package/src/sap/ui/core/service/ServiceFactory.js +1 -1
- package/src/sap/ui/core/service/ServiceFactoryRegistry.js +1 -1
- package/src/sap/ui/core/support/Plugin.js +1 -1
- package/src/sap/ui/core/support/Support.js +5 -3
- package/src/sap/ui/core/support/ToolsAPI.js +8 -4
- package/src/sap/ui/core/support/plugins/Breakpoint.js +4 -4
- package/src/sap/ui/core/support/plugins/ControlTree.js +31 -13
- package/src/sap/ui/core/support/plugins/Interaction.js +1 -1
- package/src/sap/ui/core/support/plugins/LocalStorage.js +1 -1
- package/src/sap/ui/core/support/plugins/Performance.js +1 -1
- package/src/sap/ui/core/support/plugins/Selector.js +2 -2
- package/src/sap/ui/core/support/plugins/TechInfo.js +1 -1
- package/src/sap/ui/core/support/plugins/Trace.js +1 -1
- package/src/sap/ui/core/support/plugins/ViewInfo.js +6 -4
- package/src/sap/ui/core/support/techinfo/TechnicalInfo.js +4 -2
- package/src/sap/ui/core/support/usage/EventBroadcaster.js +1 -1
- package/src/sap/ui/core/themes/base/base.less +275 -269
- package/src/sap/ui/core/themes/base/fonts/SAP-icons.ttf +0 -0
- package/src/sap/ui/core/themes/base/fonts/SAP-icons.woff2 +0 -0
- package/src/sap/ui/core/themes/base/global.less +8 -8
- package/src/sap/ui/core/theming/Parameters.js +4 -5
- package/src/sap/ui/core/theming/ThemeHelper.js +0 -1
- package/src/sap/ui/core/theming/ThemeManager.js +15 -14
- package/src/sap/ui/core/tmpl/DOMAttribute.js +1 -1
- package/src/sap/ui/core/tmpl/DOMElement.js +1 -1
- package/src/sap/ui/core/tmpl/HandlebarsTemplate.js +1 -1
- package/src/sap/ui/core/tmpl/Template.js +1 -1
- package/src/sap/ui/core/tmpl/TemplateControl.js +4 -2
- package/src/sap/ui/core/util/AsyncHintsHelper.js +1 -1
- package/src/sap/ui/core/util/Export.js +1 -1
- package/src/sap/ui/core/util/ExportCell.js +1 -1
- package/src/sap/ui/core/util/ExportColumn.js +1 -1
- package/src/sap/ui/core/util/ExportRow.js +1 -1
- package/src/sap/ui/core/util/ExportType.js +1 -1
- package/src/sap/ui/core/util/ExportTypeCSV.js +1 -1
- package/src/sap/ui/core/util/File.js +1 -1
- package/src/sap/ui/core/util/LibraryInfo.js +1 -1
- package/src/sap/ui/core/util/MockServer.js +1 -1
- package/src/sap/ui/core/util/PasteHelper.js +1 -1
- package/src/sap/ui/core/util/reflection/BaseTreeModifier.js +27 -4
- package/src/sap/ui/core/util/reflection/JsControlTreeModifier.js +55 -30
- package/src/sap/ui/core/util/reflection/XmlTreeModifier.js +54 -48
- package/src/sap/ui/core/util/serializer/HTMLViewSerializer.js +2 -2
- package/src/sap/ui/core/util/serializer/Serializer.js +3 -3
- package/src/sap/ui/core/util/serializer/ViewSerializer.js +27 -10
- package/src/sap/ui/core/util/serializer/XMLViewSerializer.js +2 -2
- package/src/sap/ui/core/util/serializer/delegate/Delegate.js +1 -1
- package/src/sap/ui/core/util/serializer/delegate/HTML.js +1 -1
- package/src/sap/ui/core/util/serializer/delegate/XML.js +1 -1
- package/src/sap/ui/core/webc/WebComponent.js +3 -3
- package/src/sap/ui/core/webc/WebComponentMetadata.js +1 -1
- package/src/sap/ui/core/ws/ReadyState.js +1 -1
- package/src/sap/ui/core/ws/SapPcpWebSocket.js +1 -1
- package/src/sap/ui/core/ws/WebSocket.js +1 -1
- package/src/sap/ui/debug/ControlTree.js +5 -5
- package/src/sap/ui/debug/DebugEnv.js +15 -6
- package/src/sap/ui/debug/PropertyList.js +3 -3
- package/src/sap/ui/dom/jquery/control.js +3 -4
- package/src/sap/ui/events/F6Navigation.js +2 -1
- package/src/sap/ui/model/ClientModel.js +33 -1
- package/src/sap/ui/model/ClientPropertyBinding.js +17 -1
- package/src/sap/ui/model/CompositeDataState.js +1 -1
- package/src/sap/ui/model/CompositeType.js +1 -1
- package/src/sap/ui/model/DataState.js +1 -1
- package/src/sap/ui/model/Filter.js +1 -1
- package/src/sap/ui/model/MetaModel.js +1 -1
- package/src/sap/ui/model/Model.js +1 -1
- package/src/sap/ui/model/SelectionModel.js +1 -1
- package/src/sap/ui/model/SimpleType.js +1 -1
- package/src/sap/ui/model/TreeAutoExpandMode.js +1 -1
- package/src/sap/ui/model/Type.js +1 -1
- package/src/sap/ui/model/json/JSONModel.js +2 -3
- package/src/sap/ui/model/message/MessageModel.js +3 -7
- package/src/sap/ui/model/odata/ODataAnnotations.js +1 -1
- package/src/sap/ui/model/odata/ODataMessageParser.js +1 -1
- package/src/sap/ui/model/odata/ODataMetaModel.js +1 -1
- package/src/sap/ui/model/odata/ODataMetadata.js +1 -1
- package/src/sap/ui/model/odata/ODataModel.js +1 -1
- package/src/sap/ui/model/odata/type/Boolean.js +1 -1
- package/src/sap/ui/model/odata/type/Byte.js +1 -1
- package/src/sap/ui/model/odata/type/Currency.js +1 -1
- package/src/sap/ui/model/odata/type/Date.js +1 -1
- package/src/sap/ui/model/odata/type/DateTime.js +1 -1
- package/src/sap/ui/model/odata/type/DateTimeBase.js +1 -1
- package/src/sap/ui/model/odata/type/DateTimeOffset.js +1 -1
- package/src/sap/ui/model/odata/type/DateTimeWithTimezone.js +1 -2
- package/src/sap/ui/model/odata/type/Decimal.js +1 -1
- package/src/sap/ui/model/odata/type/Double.js +1 -1
- package/src/sap/ui/model/odata/type/Guid.js +1 -1
- package/src/sap/ui/model/odata/type/Int.js +1 -1
- package/src/sap/ui/model/odata/type/Int16.js +1 -1
- package/src/sap/ui/model/odata/type/Int32.js +1 -1
- package/src/sap/ui/model/odata/type/Int64.js +1 -1
- package/src/sap/ui/model/odata/type/ODataType.js +2 -3
- package/src/sap/ui/model/odata/type/Raw.js +1 -1
- package/src/sap/ui/model/odata/type/SByte.js +1 -1
- package/src/sap/ui/model/odata/type/Single.js +1 -1
- package/src/sap/ui/model/odata/type/Stream.js +1 -1
- package/src/sap/ui/model/odata/type/String.js +1 -1
- package/src/sap/ui/model/odata/type/Time.js +1 -1
- package/src/sap/ui/model/odata/type/TimeOfDay.js +1 -1
- package/src/sap/ui/model/odata/type/Unit.js +1 -1
- package/src/sap/ui/model/odata/v2/Context.js +13 -5
- package/src/sap/ui/model/odata/v2/ODataAnnotations.js +1 -1
- package/src/sap/ui/model/odata/v2/ODataListBinding.js +85 -56
- package/src/sap/ui/model/odata/v2/ODataModel.js +20 -15
- package/src/sap/ui/model/odata/v2/ODataTreeBinding.js +1 -1
- package/src/sap/ui/model/odata/v4/Context.js +60 -10
- package/src/sap/ui/model/odata/v4/ODataBinding.js +13 -4
- package/src/sap/ui/model/odata/v4/ODataContextBinding.js +159 -34
- package/src/sap/ui/model/odata/v4/ODataListBinding.js +94 -24
- package/src/sap/ui/model/odata/v4/ODataMetaModel.js +1 -1
- package/src/sap/ui/model/odata/v4/ODataModel.js +10 -10
- package/src/sap/ui/model/odata/v4/ODataParentBinding.js +4 -2
- package/src/sap/ui/model/odata/v4/ODataPropertyBinding.js +10 -13
- package/src/sap/ui/model/odata/v4/lib/_AggregationCache.js +105 -25
- package/src/sap/ui/model/odata/v4/lib/_AggregationHelper.js +3 -5
- package/src/sap/ui/model/odata/v4/lib/_Cache.js +83 -24
- package/src/sap/ui/model/odata/v4/lib/_Helper.js +6 -20
- package/src/sap/ui/model/odata/v4/lib/_Requestor.js +3 -3
- package/src/sap/ui/model/odata/v4/lib/_V2MetadataConverter.js +1 -1
- package/src/sap/ui/model/resource/ResourceModel.js +1 -1
- package/src/sap/ui/model/type/Boolean.js +1 -1
- package/src/sap/ui/model/type/Currency.js +1 -1
- package/src/sap/ui/model/type/Date.js +1 -2
- package/src/sap/ui/model/type/DateInterval.js +1 -2
- package/src/sap/ui/model/type/DateTime.js +1 -1
- package/src/sap/ui/model/type/DateTimeInterval.js +1 -1
- package/src/sap/ui/model/type/FileSize.js +1 -1
- package/src/sap/ui/model/type/Float.js +1 -1
- package/src/sap/ui/model/type/Integer.js +1 -1
- package/src/sap/ui/model/type/String.js +1 -1
- package/src/sap/ui/model/type/Time.js +1 -1
- package/src/sap/ui/model/type/TimeInterval.js +1 -1
- package/src/sap/ui/model/type/Unit.js +1 -1
- package/src/sap/ui/model/xml/XMLModel.js +2 -2
- package/src/sap/ui/model/xml/XMLPropertyBinding.js +4 -2
- package/src/sap/ui/performance/BeaconRequest.js +8 -10
- package/src/sap/ui/qunit/qunit-coverage-istanbul.js +60 -6
- package/src/sap/ui/qunit/utils/ControlIterator.js +1 -1
- package/src/sap/ui/qunit/utils/MemoryLeakCheck.js +1 -1
- package/src/sap/ui/qunit/utils/waitForThemeApplied.js +16 -14
- package/src/sap/ui/test/BlanketReporterUI.view.xml +5 -2
- package/src/sap/ui/test/OpaPlugin.js +3 -3
- package/src/sap/ui/test/TestUtils.js +3 -3
- package/src/sap/ui/test/generic/TestBase.js +1 -1
- package/src/sap/ui/test/matchers/Descendant.js +1 -1
- package/src/sap/ui/test/matchers/Sibling.js +1 -1
- package/src/sap/ui/test/selectors/_LabelFor.js +3 -2
- package/src/sap/ui/test/starter/_setupAndStart.js +35 -11
- package/src/sap/ui/util/Storage.js +1 -1
- package/test/sap/ui/core/HTMLControl.html +94 -93
- package/test/sap/ui/core/HyphenationPlayground.html +10 -9
- package/test/sap/ui/core/Strings.view.xml +5 -1
- package/test/sap/ui/core/ThemeParameters.html +31 -30
- package/test/sap/ui/core/ValidateURL.html +10 -10
- package/test/sap/ui/core/demokit/sample/BusyIndicator/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/Commands/manifest.json +2 -2
- package/test/sap/ui/core/demokit/sample/ControlBusyIndicator/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/ControllerExtension/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/FieldGroup/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/Html/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/Html/preserveDOM/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/Html/static/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/HyphenationAPI/C.controller.js +3 -3
- package/test/sap/ui/core/demokit/sample/Icon/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/InvisibleMessage/InvisibleMessage.controller.js +4 -4
- package/test/sap/ui/core/demokit/sample/InvisibleMessage/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/InvisibleText/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/MessageManager/BasicODataMessages/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/OpaAction/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/OpaAutoWaitParams/OpaAutoWaitParams.js +1 -1
- package/test/sap/ui/core/demokit/sample/OpaAutoWaitParams/applicationUnderTest/manifest.json +2 -2
- package/test/sap/ui/core/demokit/sample/OpaAutoWaitParams/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/OpaBusyIndicator/applicationUnderTest/manifest.json +2 -2
- package/test/sap/ui/core/demokit/sample/OpaBusyIndicator/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/OpaById/applicationUnderTest/manifest.json +2 -2
- package/test/sap/ui/core/demokit/sample/OpaById/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/OpaDynamicWait/applicationUnderTest/manifest.json +2 -2
- package/test/sap/ui/core/demokit/sample/OpaDynamicWait/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/OpaGetStarted/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/OpaMatchers/applicationUnderTest/manifest.json +2 -2
- package/test/sap/ui/core/demokit/sample/OpaMatchers/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/OpaPageObject/applicationUnderTest/manifest.json +2 -2
- package/test/sap/ui/core/demokit/sample/OpaPageObject/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/OpaStartup/iStartMyAppInAFrame/applicationUnderTest/manifest.json +2 -2
- package/test/sap/ui/core/demokit/sample/OpaStartup/iStartMyAppInAFrame/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/OpaStartup/iStartMyUIComponent/applicationUnderTest/manifest.json +2 -2
- package/test/sap/ui/core/demokit/sample/OpaStartup/iStartMyUIComponent/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/OpaStaticAreaControls/applicationUnderTest/manifest.json +2 -2
- package/test/sap/ui/core/demokit/sample/OpaStaticAreaControls/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/OpaTestLibrary/applicationUnderTest/manifest.json +2 -2
- package/test/sap/ui/core/demokit/sample/OpaTestLibrary/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/OpaURLParameters/iStartMyAppInAFrameWithURLParameters/applicationUnderTest/manifest.json +2 -2
- package/test/sap/ui/core/demokit/sample/OpaURLParameters/iStartMyAppInAFrameWithURLParameters/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/OpaURLParameters/iStartMyUIComponentWithURLParameters/applicationUnderTest/manifest.json +2 -2
- package/test/sap/ui/core/demokit/sample/OpaURLParameters/iStartMyUIComponentWithURLParameters/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/OpaWithSupportAssistant/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/PatternMatching/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/PatternMatching/patternApp/manifest.json +2 -2
- package/test/sap/ui/core/demokit/sample/RoutingFullscreen/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/RoutingMasterDetail/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/RoutingNestedComponent/manifest.json +2 -2
- package/test/sap/ui/core/demokit/sample/RoutingNestedComponent/reuse/categories/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/RoutingNestedComponent/reuse/products/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/RoutingNestedComponent/reuse/suppliers/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/TargetsStandalone/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/ThemeCustomClasses/ThemeCustomClasses.controller.js +3 -3
- package/test/sap/ui/core/demokit/sample/ThemeCustomClasses/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/TypeCurrency/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/TypeDateAsDate/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/TypeDateAsString/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/TypeDateTime/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/TypeFileSize/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/TypeFloat/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/TypeInteger/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/TypeTimeAsTime/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/View/async/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/View/preprocessor/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/ViewTemplate/scenario/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/XMLComposite/02/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/common/Controller.js +3 -2
- package/test/sap/ui/core/demokit/sample/common/Helper.js +15 -2
- package/test/sap/ui/core/demokit/sample/common/pages/Any.js +3 -0
- package/test/sap/ui/core/demokit/sample/gherkin/GherkinWithPageObjects/applicationUnderTest/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/gherkin/GherkinWithPageObjects/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/matcher/BindingPath/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/matcher/BindingPath/webapp/manifest.json +2 -2
- package/test/sap/ui/core/demokit/sample/matcher/Descendant/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/matcher/Descendant/webapp/manifest.json +2 -2
- package/test/sap/ui/core/demokit/sample/matcher/I18NText/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/matcher/I18NText/webapp/manifest.json +2 -2
- package/test/sap/ui/core/demokit/sample/matcher/LabelFor/manifest.json +2 -1
- package/test/sap/ui/core/demokit/sample/matcher/LabelFor/webapp/manifest.json +2 -2
- package/test/sap/ui/core/demokit/sample/odata/types/v2/DateTimeOffset/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/odata/types/v4/Date/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/odata/types/v4/TimeOfDay/manifest.json +1 -0
- package/test/sap/ui/core/demokit/sample/odata/v2/AutoExpand/AutoExpand.view.xml +6 -2
- package/test/sap/ui/core/demokit/sample/odata/v4/Ancestry/Main.view.xml +7 -3
- package/test/sap/ui/core/demokit/sample/odata/v4/DataAggregation/DataAggregation.controller.js +2 -2
- package/test/sap/ui/core/demokit/sample/odata/v4/DataAggregation/DataAggregation.view.xml +7 -4
- package/test/sap/ui/core/demokit/sample/odata/v4/DataAggregation/tests/expandPageCollapse.js +1 -1
- package/test/sap/ui/core/demokit/sample/odata/v4/DataAggregation/tests/filter.js +1 -1
- package/test/sap/ui/core/demokit/sample/odata/v4/DeepCreate/Opa.qunit.js +1 -1
- package/test/sap/ui/core/demokit/sample/odata/v4/Draft/Opa.qunit.js +3 -5
- package/test/sap/ui/core/demokit/sample/odata/v4/FieldGroups/Opa.qunit.js +4 -2
- package/test/sap/ui/core/demokit/sample/odata/v4/FlatDataAggregation/FlatDataAggregation.controller.js +6 -4
- package/test/sap/ui/core/demokit/sample/odata/v4/FlatDataAggregation/FlatDataAggregation.view.xml +6 -2
- package/test/sap/ui/core/demokit/sample/odata/v4/FlexibleColumnLayout/Opa.qunit.js +9 -16
- package/test/sap/ui/core/demokit/sample/odata/v4/GridTable/GridTable.view.xml +6 -2
- package/test/sap/ui/core/demokit/sample/odata/v4/HierarchyBindAction/Main.view.xml +7 -3
- package/test/sap/ui/core/demokit/sample/odata/v4/LateProperties/Opa.qunit.js +1 -1
- package/test/sap/ui/core/demokit/sample/odata/v4/ListBinding/Opa.qunit.js +1 -1
- package/test/sap/ui/core/demokit/sample/odata/v4/MultipleInlineCreationRowsGrid/Main.view.xml +5 -2
- package/test/sap/ui/core/demokit/sample/odata/v4/MultipleInlineCreationRowsGrid/Opa.qunit.js +4 -2
- package/test/sap/ui/core/demokit/sample/odata/v4/Products/Opa.qunit.js +1 -1
- package/test/sap/ui/core/demokit/sample/odata/v4/RecursiveHierarchy/RecursiveHierarchy.controller.js +29 -4
- package/test/sap/ui/core/demokit/sample/odata/v4/RecursiveHierarchy/RecursiveHierarchy.view.xml +30 -5
- package/test/sap/ui/core/demokit/sample/odata/v4/RecursiveHierarchy/SandboxModel.js +33 -6
- package/test/sap/ui/core/demokit/sample/odata/v4/RecursiveHierarchy/tests/createEdit.js +1 -1
- package/test/sap/ui/core/demokit/sample/odata/v4/RecursiveHierarchy/tests/pageExpandCollapse.js +1 -1
- package/test/sap/ui/core/demokit/sample/odata/v4/SalesOrderTP100_V2/Opa.qunit.js +1 -1
- package/test/sap/ui/core/demokit/sample/odata/v4/SalesOrderTP100_V4/Opa.qunit.js +1 -1
- package/test/sap/ui/core/demokit/sample/odata/v4/SalesOrders/pages/Main.js +9 -8
- package/test/sap/ui/core/demokit/sample/odata/v4/SalesOrders/tests/ChangeContext.js +1 -1
- package/test/sap/ui/core/demokit/sample/odata/v4/SalesOrders/tests/Create.js +1 -1
- package/test/sap/ui/core/demokit/sample/odata/v4/SalesOrders/tests/CreateMultiple.js +1 -1
- package/test/sap/ui/core/demokit/sample/odata/v4/SalesOrders/tests/CreateRelative.js +1 -1
- package/test/sap/ui/core/demokit/sample/odata/v4/SalesOrders/tests/MessageHandling.js +1 -1
- package/test/sap/ui/core/demokit/sample/odata/v4/SalesOrders/tests/TypeDeterminationAndDelete.js +8 -9
- package/test/sap/ui/core/demokit/sample/odata/v4/SalesOrders/tests/WriteNonDeferredGroup.js +1 -1
- package/test/sap/ui/core/demokit/sample/odata/v4/SalesOrders/tests/additionalTargets.js +1 -1
- package/test/sap/ui/core/demokit/sample/odata/v4/SalesOrdersRTATest/tests/AdaptSalesOrdersTable.js +1 -1
- package/test/sap/ui/core/demokit/sample/odata/v4/SalesOrdersTemplate/Opa.qunit.js +1 -1
- package/test/sap/ui/core/demokit/sample/odata/v4/ServerDrivenPaging/Main.view.xml +5 -2
- package/test/sap/ui/core/demokit/sample/odata/v4/ServerDrivenPaging/pages/Main.js +4 -2
- package/test/sap/ui/core/demokit/sample/odata/v4/Sticky/Opa.qunit.js +1 -1
- package/test/sap/ui/core/demokit/tutorial/mockserver/01/webapp/manifest.json +1 -1
- package/test/sap/ui/core/demokit/tutorial/mockserver/02/webapp/manifest.json +1 -1
- package/test/sap/ui/core/demokit/tutorial/mockserver/03/webapp/manifest.json +1 -1
- package/test/sap/ui/core/demokit/tutorial/mockserver/04/webapp/manifest.json +1 -1
- package/test/sap/ui/core/demokit/tutorial/troubleshooting/01/webapp/manifest.json +1 -1
- package/test/sap/ui/core/internal/samples/composite/xmlcomposite/exTableWrapperOuterBinding/Test.controller.js +3 -2
- package/test/sap/ui/core/internal/samples/odata/v2/SalesOrders/Main.controller.js +1 -1
- package/test/sap/ui/core/internal/samples/odata/v2/SalesOrders/Main.view.xml +6 -3
- package/test/sap/ui/core/internal/samples/odata/v2/TreeTable/Main.view.xml +1 -1
- package/test/sap/ui/core/qunit/ControlDefinition.qunit.js +40 -20
- package/test/sap/ui/core/qunit/ControlRenderer.qunit.js +1 -1
- package/test/sap/ui/core/qunit/Core.qunit.js +5 -4
- package/test/sap/ui/core/qunit/Core_libraryTerminologies_integration.qunit.js +12 -11
- package/test/sap/ui/core/qunit/CustomStyleClassSupport.qunit.js +119 -117
- package/test/sap/ui/core/qunit/CustomThemeFallback.qunit.js +5 -17
- package/test/sap/ui/core/qunit/Declarative.qunit.js +37 -37
- package/test/sap/ui/core/qunit/Element_base.qunit.js +1 -1
- package/test/sap/ui/core/qunit/EventBus.qunit.js +4 -3
- package/test/sap/ui/core/qunit/FastNavigation.qunit.js +3 -2
- package/test/sap/ui/core/qunit/FieldGroup.qunit.js +9 -8
- package/test/sap/ui/core/qunit/FocusHandler.qunit.js +5 -4
- package/test/sap/ui/core/qunit/Fragment.qunit.js +12 -12
- package/test/sap/ui/core/qunit/Fragment_legacyAPIs.qunit.js +13 -12
- package/test/sap/ui/core/qunit/HTML.qunit.js +35 -35
- package/test/sap/ui/core/qunit/IconPool.qunit.js +6 -6
- package/test/sap/ui/core/qunit/InvisibleText.qunit.js +5 -4
- package/test/sap/ui/core/qunit/ManagedObject.qunit.js +3 -3
- package/test/sap/ui/core/qunit/PlaceAt.qunit.js +2 -2
- package/test/sap/ui/core/qunit/ScrollBar.qunit.js +3 -3
- package/test/sap/ui/core/qunit/StashedControlSupport.qunit.js +9 -9
- package/test/sap/ui/core/qunit/ThemeHelper.qunit.js +5 -4
- package/test/sap/ui/core/qunit/ThemeManager.qunit.js +47 -79
- package/test/sap/ui/core/qunit/ThemeParameters.qunit.js +40 -372
- package/test/sap/ui/core/qunit/ThemeParameters_legacyAPIs.qunit.js +686 -0
- package/test/sap/ui/core/qunit/TooltipBase.qunit.js +3 -2
- package/test/sap/ui/core/qunit/UIArea.qunit.js +10 -10
- package/test/sap/ui/core/qunit/analytics/testsuite4analytics.qunit.html +3 -3
- package/test/sap/ui/core/qunit/base/i18n/Localization.qunit.js +4 -3
- package/test/sap/ui/core/qunit/base/i18n/ResourceBundle.qunit.js +13 -3
- package/test/sap/ui/core/qunit/base/util/UriParameters.qunit.js +27 -1
- package/test/sap/ui/core/qunit/bootstrap/BootstrapCustomBootTaskPreloadCss.qunit.js +4 -4
- package/test/sap/ui/core/qunit/bootstrap/BootstrapWithCustomBootTask.beforeBootstrap.qunit.js +22 -21
- package/test/sap/ui/core/qunit/bootstrap/BootstrapWithCustomBootTask.qunit.js +4 -9
- package/test/sap/ui/core/qunit/bootstrap/CalendarClassLoadingWithCustomBootTaskAndPreload.qunit.js +19 -4
- package/test/sap/ui/core/qunit/bootstrap/CfgDefaults.qunit.js +3 -2
- package/test/sap/ui/core/qunit/bootstrap/CfgFromConfigAttribute.qunit.js +4 -3
- package/test/sap/ui/core/qunit/bootstrap/CfgFromGlobalObject.qunit.js +4 -3
- package/test/sap/ui/core/qunit/bootstrap/CfgFromTagAttributes.qunit.js +4 -3
- package/test/sap/ui/core/qunit/bootstrap/Configuration.qunit.js +2 -198
- package/test/sap/ui/core/qunit/bootstrap/Configuration_language_via_URL.qunit.js +210 -0
- package/test/sap/ui/core/qunit/bootstrap/ThemeVersion.qunit.js +33 -30
- package/test/sap/ui/core/qunit/bootstrap/testsuite.bootstrap.qunit.js +6 -0
- package/test/sap/ui/core/qunit/component/Component.qunit.js +12 -0
- package/test/sap/ui/core/qunit/component/ComponentSupport.qunit.js +6 -5
- package/test/sap/ui/core/qunit/component/Component_dependencyLoading.qunit.js +15 -9
- package/test/sap/ui/core/qunit/component/Component_dependencyLoading_unavoidablySync.qunit.js +10 -6
- package/test/sap/ui/core/qunit/component/Customizing.qunit.js +8 -7
- package/test/sap/ui/core/qunit/component/Customizing_disabled.qunit.js +6 -5
- package/test/sap/ui/core/qunit/component/Customizing_legacyAPIs.qunit.js +8 -7
- package/test/sap/ui/core/qunit/component/Customizing_multi.qunit.js +7 -6
- package/test/sap/ui/core/qunit/component/Customizing_unavoidablySync.qunit.js +5 -4
- package/test/sap/ui/core/qunit/component/Metadata.qunit.js +3 -3
- package/test/sap/ui/core/qunit/component/Models.qunit.js +103 -44
- package/test/sap/ui/core/qunit/component/UIComponent.qunit.js +20 -4
- package/test/sap/ui/core/qunit/component/UIComponent_unavoidablySync.qunit.js +5 -4
- package/test/sap/ui/core/qunit/component/testdata/dependencyLoading/component1/manifest.json +2 -1
- package/test/sap/ui/core/qunit/component/testdata/dependencyLoading/component2/manifest.json +1 -0
- package/test/sap/ui/core/qunit/component/testdata/dependencyLoading/component3/manifest.json +2 -1
- package/test/sap/ui/core/qunit/component/testdata/dependencyLoading/component4/manifest.json +1 -0
- package/test/sap/ui/core/qunit/component/testdata/dependencyLoading/component5/manifest.json +1 -1
- package/test/sap/ui/core/qunit/component/testdata/dependencyLoading/component6/manifest.json +1 -0
- package/test/sap/ui/core/qunit/component/testdata/dependencyLoading/componentVariant/manifest.json +1 -0
- package/test/sap/ui/core/qunit/component/testdata/v2asyncRootView/manifest.json +1 -1
- package/test/sap/ui/core/qunit/component/testdata/v2inline/Component.js +1 -1
- package/test/sap/ui/core/qunit/composite/XMLComposite.qunit.js +5 -5
- package/test/sap/ui/core/qunit/internal/1RingModels.qunit.html +4 -5
- package/test/sap/ui/core/qunit/internal/1RingModels.qunit.js +1 -0
- package/test/sap/ui/core/qunit/internal/AnnotationParser.qunit.html +4 -4
- package/test/sap/ui/core/qunit/internal/testsuite.models.qunit.js +19 -9
- package/test/sap/ui/core/qunit/jquery.sap.global-config.qunit.js +2 -4
- package/test/sap/ui/core/qunit/jquery.sap.ui.qunit.js +5 -4
- package/test/sap/ui/core/qunit/json/JSONModel.qunit.js +5 -9
- package/test/sap/ui/core/qunit/messages/Messaging.qunit.js +10 -5
- package/test/sap/ui/core/qunit/messages/messagesGeneral.qunit.js +6 -0
- package/test/sap/ui/core/qunit/messages/messagesGeneral_legacyAPIs.qunit.js +158 -0
- package/test/sap/ui/core/qunit/messages/messagesUsage.qunit.js +5 -4
- package/test/sap/ui/core/qunit/messages/testsuite.messaging.base.qunit.js +7 -0
- package/test/sap/ui/core/qunit/model/ClientPropertyBinding.qunit.js +47 -0
- package/test/sap/ui/core/qunit/mvc/AsyncXMLView.qunit.js +5 -3
- package/test/sap/ui/core/qunit/mvc/Controller.qunit.js +3 -3
- package/test/sap/ui/core/qunit/mvc/View.qunit.js +5 -1
- package/test/sap/ui/core/qunit/mvc/XMLView.qunit.js +6 -5
- package/test/sap/ui/core/qunit/mvc/testdata/TypedViewWithRendererRenderer.js +2 -2
- package/test/sap/ui/core/qunit/mvc/testdata/stashed/manifest.json +2 -1
- package/test/sap/ui/core/qunit/mvc/viewprocessing/ViewProcessing.qunit.js +4 -3
- package/test/sap/ui/core/qunit/mvc/viewprocessing/ViewProcessing_legacyAPIs.qunit.js +4 -3
- package/test/sap/ui/core/qunit/mvc_legacyAPIs/AsyncXMLView_legacyAPIs.qunit.js +5 -3
- package/test/sap/ui/core/qunit/mvc_legacyAPIs/XMLView_legacyAPIs.qunit.js +6 -5
- package/test/sap/ui/core/qunit/odata/ODataMessageParserNoFakeService.qunit.js +11 -7
- package/test/sap/ui/core/qunit/odata/ODataMetaModel.qunit.js +35 -0
- package/test/sap/ui/core/qunit/odata/_AnnotationHelperBasics.qunit.js +10 -4
- package/test/sap/ui/core/qunit/odata/data/ODataModelFakeService.js +1 -1
- package/test/sap/ui/core/qunit/odata/type/DateTimeBase.qunit.js +5 -0
- package/test/sap/ui/core/qunit/odata/type/ODataType.qunit.js +9 -0
- package/test/sap/ui/core/qunit/odata/v2/Context.qunit.js +12 -0
- package/test/sap/ui/core/qunit/odata/v2/ODataListBindingNoFakeService.qunit.js +422 -9
- package/test/sap/ui/core/qunit/odata/v2/ODataModel.integration.qunit.js +483 -33
- package/test/sap/ui/core/qunit/odata/v2/ODataModelNoFakeService.qunit.js +121 -2
- package/test/sap/ui/core/qunit/odata/v4/Context.qunit.js +95 -8
- package/test/sap/ui/core/qunit/odata/v4/ODataBinding.qunit.js +59 -13
- package/test/sap/ui/core/qunit/odata/v4/ODataContextBinding.qunit.js +355 -75
- package/test/sap/ui/core/qunit/odata/v4/ODataListBinding.qunit.js +152 -19
- package/test/sap/ui/core/qunit/odata/v4/ODataModel.integration.qunit.js +1253 -130
- package/test/sap/ui/core/qunit/odata/v4/ODataParentBinding.qunit.js +19 -9
- package/test/sap/ui/core/qunit/odata/v4/ODataPropertyBinding.qunit.js +6 -27
- package/test/sap/ui/core/qunit/odata/v4/data/metadata.json +3 -1
- package/test/sap/ui/core/qunit/odata/v4/data/metadata.xml +2 -2
- package/test/sap/ui/core/qunit/odata/v4/lib/_AggregationCache.qunit.js +172 -17
- package/test/sap/ui/core/qunit/odata/v4/lib/_AggregationHelper.qunit.js +7 -8
- package/test/sap/ui/core/qunit/odata/v4/lib/_Cache.qunit.js +185 -84
- package/test/sap/ui/core/qunit/odata/v4/lib/_Helper.qunit.js +2 -22
- package/test/sap/ui/core/qunit/opa/OpaPlugin.qunit.js +6 -4
- package/test/sap/ui/core/qunit/opa/selectors/_Selector.js +3 -2
- package/test/sap/ui/core/qunit/opa/selectors/_TableRowItem.js +4 -3
- package/test/sap/ui/core/qunit/rule/app/deprecatedJSViewUsage.qunit.js +4 -0
- package/test/sap/ui/core/qunit/rule/app/globalApiUsage.qunit.js +4 -0
- package/test/sap/ui/core/qunit/rule/app/jquerySapUsage.qunit.js +4 -0
- package/test/sap/ui/core/qunit/rule/app/syncXHR.qunit.js +4 -0
- package/test/sap/ui/core/qunit/rule/app/syncXHRBootstrap.qunit.js +4 -0
- package/test/sap/ui/core/qunit/rule/app/syncXHRBootstrapDebug.qunit.js +4 -0
- package/test/sap/ui/core/qunit/rule/app/syncXHRBootstrapDebugBeforeBootstrap.js +4 -0
- package/test/sap/ui/core/qunit/rule/config/asynchronousXMLViews.qunit.js +4 -1
- package/test/sap/ui/core/qunit/rule/misc/silentEventBus.qunit.js +8 -7
- package/test/sap/ui/core/qunit/rule/model/modelSupport.qunit.js +11 -2
- package/test/sap/ui/core/qunit/rule/testsuite.rule.qunit.js +18 -0
- package/test/sap/ui/core/qunit/test/starter/find/main.js +11 -8
- package/test/sap/ui/core/qunit/testsuites/testsuite.databinding.qunit.js +6 -0
- package/test/sap/ui/core/qunit/testsuites/testsuite.foundation.enablement.qunit.js +7 -1
- package/test/sap/ui/core/qunit/testsuites/testsuite.theming.qunit.js +21 -2
- package/test/sap/ui/core/qunit/util/XMLPreprocessor.qunit.js +26 -4
- package/test/sap/ui/core/qunit/util/jQuery.sap.Version.qunit.js +5 -5
- package/test/sap/ui/core/qunit/util/reflection/JsControlTreeModifier.qunit.js +30 -13
- package/test/sap/ui/core/qunit/util/reflection/XmlTreeModifier.qunit.js +40 -16
- package/test/sap/ui/core/qunit/util/support/TechnicalInfo.qunit.js +11 -10
- package/test/sap/ui/core/qunit/xml/XMLPropertyBinding.qunit.js +69 -8
- package/test/sap/ui/core/relnotes/changes-1.118.json +1 -34
- package/test/sap/ui/core/relnotes/changes-1.119.json +217 -0
- package/test/sap/ui/core/resources/fastnav.js +3 -2
- package/test/sap/ui/core/samples/ResponsiveDemo.html +3 -3
- package/test/sap/ui/core/samples/components/commands/manifest.json +2 -2
- package/test/sap/ui/core/samples/components/sample/manifest.json +2 -1
- package/test/sap/ui/core/samples/databinding/DatabindingMessages.html +1 -1
- package/test/sap/ui/core/samples/databinding/ODatabindingMessages.html +3 -3
- package/test/sap/ui/core/samples/databinding/UnitTable.view.xml +9 -2
- package/test/sap/ui/core/samples/formatting/manifest.json +2 -2
- package/test/sap/ui/core/samples/mvc/XMLViewAsync.html +62 -61
- package/test/sap/ui/core/samples/routing_legacyAPIs/AsyncViews.html +124 -123
- package/test/sap/ui/core/terminologies/App.controller.js +3 -2
- package/test/sap/ui/core/terminologies/App.view.xml +64 -64
- package/test/sap/ui/core/tmpl_legacyAPIs/TemplateSimple.html +38 -37
- package/test/sap/ui/core/util/PasteHelper.html +5 -4
- package/test/sap/ui/core/visual/images/ContextMenuSupport/windows/1600x1200/chrome/horizon/ltr/cozy/firstItem-contextMenu.ref.lnk +1 -1
- package/test/sap/ui/core/visual/images/ContextMenuSupport/windows/1600x1200/chrome/horizon/ltr/cozy/initial.ref.lnk +1 -1
- package/test/sap/ui/core/visual/images/ContextMenuSupport/windows/1600x1200/chrome/horizon/ltr/cozy/lastItem-contextMenu.ref.lnk +1 -1
- package/test/sap/ui/core/visual/images/ContextMenuSupport/windows/1600x1200/chrome/horizon/ltr/cozy/leftDownBtn-contextMenu.ref.lnk +1 -1
- package/test/sap/ui/core/visual/images/ContextMenuSupport/windows/1600x1200/chrome/horizon/ltr/cozy/myButtonSample-contextMenu.ref.lnk +1 -1
- package/test/sap/ui/core/visual/images/ContextMenuSupport/windows/1600x1200/chrome/horizon/ltr/cozy/rightDownBtn-contextMenu.ref.lnk +1 -1
- package/test/sap/ui/core/samples/databinding/DataBinding.html +0 -135
- package/test/sap/ui/core/samples/databinding/DataBindingCalculatedFields.html +0 -229
- package/test/sap/ui/core/samples/databinding/DataBindingCompositeTypes.html +0 -273
- package/test/sap/ui/core/samples/databinding/DataBindingFormat.html +0 -294
- package/test/sap/ui/core/samples/databinding/DataBindingList.html +0 -290
- package/test/sap/ui/core/samples/databinding/DataBindingListNamedModel.html +0 -290
- package/test/sap/ui/core/samples/databinding/DataBindingListXML.html +0 -280
- package/test/sap/ui/core/samples/databinding/DataBindingMasterDetail.html +0 -117
- package/test/sap/ui/core/samples/databinding/DataBindingMultiModel.html +0 -154
- package/test/sap/ui/core/samples/databinding/DataBindingResourceModel.html +0 -119
- package/test/sap/ui/core/samples/databinding/DataBindingSortingFiltering.html +0 -103
- package/test/sap/ui/core/samples/databinding/DataBindingTree.html +0 -166
- package/test/sap/ui/core/samples/databinding/DataBindingTreeFilter.html +0 -117
- package/test/sap/ui/core/samples/databinding/DataBindingTreeFilterXML.html +0 -103
- package/test/sap/ui/core/samples/databinding/DataBindingTreeLarge.html +0 -128
- package/test/sap/ui/core/samples/databinding/DataBindingTreeWithArrays.html +0 -132
- package/test/sap/ui/core/samples/databinding/DataBindingTwoWay.html +0 -158
- package/test/sap/ui/core/samples/databinding/DataBindingTwoWayTable.html +0 -141
- package/test/sap/ui/core/samples/databinding/DataBindingTypes.html +0 -265
- package/test/sap/ui/core/samples/databinding/DataBindingValidation.html +0 -195
- package/test/sap/ui/core/samples/databinding/DataBindingXML.html +0 -148
- package/test/sap/ui/core/samples/databinding/DataBindingXMLView.html +0 -53
- package/test/sap/ui/core/samples/databinding/testdata/ListBinding.view.xml +0 -9
- package/test/sap/ui/core/samples/databinding/testdata/test.view.json +0 -15
- package/test/sap/ui/core/samples/databinding/testdata/test.view.xml +0 -8
|
@@ -142,6 +142,7 @@ sap.ui.define([
|
|
|
142
142
|
assert.strictEqual(oBinding.bInheritExpandSelect, bInheritExpandSelect);
|
|
143
143
|
assert.deepEqual(oBinding.oOperation, {
|
|
144
144
|
bAction : undefined,
|
|
145
|
+
bAdditionalQueryOptionsForRVC : undefined,
|
|
145
146
|
mChangeListeners : {},
|
|
146
147
|
mParameters : {},
|
|
147
148
|
mRefreshParameters : {}
|
|
@@ -1540,8 +1541,7 @@ sap.ui.define([
|
|
|
1540
1541
|
.withExactArgs("", "groupId", true)
|
|
1541
1542
|
.returns(SyncPromise.resolve(Promise.resolve()));
|
|
1542
1543
|
this.mock(oBinding).expects("handleOperationResult")
|
|
1543
|
-
.withExactArgs("
|
|
1544
|
-
undefined)
|
|
1544
|
+
.withExactArgs("~oOperationMetadata~", "~oResult~", undefined)
|
|
1545
1545
|
.returns(undefined);
|
|
1546
1546
|
|
|
1547
1547
|
// code under test
|
|
@@ -1625,8 +1625,7 @@ sap.ui.define([
|
|
|
1625
1625
|
}
|
|
1626
1626
|
expectChangeAndRefreshDependent(oGroupLock0);
|
|
1627
1627
|
oBindingMock.expects("handleOperationResult")
|
|
1628
|
-
.withExactArgs(
|
|
1629
|
-
undefined)
|
|
1628
|
+
.withExactArgs("~oOperationMetadata~", oResponseEntity, undefined)
|
|
1630
1629
|
.returns(undefined);
|
|
1631
1630
|
|
|
1632
1631
|
// code under test
|
|
@@ -1664,7 +1663,7 @@ sap.ui.define([
|
|
|
1664
1663
|
}
|
|
1665
1664
|
expectChangeAndRefreshDependent(oGroupLock1);
|
|
1666
1665
|
oBindingMock.expects("handleOperationResult")
|
|
1667
|
-
.withExactArgs(
|
|
1666
|
+
.withExactArgs("~oOperationMetadata~", undefined, undefined)
|
|
1668
1667
|
.returns(undefined);
|
|
1669
1668
|
|
|
1670
1669
|
// code under test: execute creates a new cache with the new path
|
|
@@ -1734,8 +1733,7 @@ sap.ui.define([
|
|
|
1734
1733
|
oBindingMock.expects("refreshDependentBindings").withExactArgs("", "groupId", true)
|
|
1735
1734
|
.returns(asyncRefresh());
|
|
1736
1735
|
oBindingMock.expects("handleOperationResult")
|
|
1737
|
-
.withExactArgs(
|
|
1738
|
-
"~oOperationMetadata~", "~ResponseEntity0~", undefined)
|
|
1736
|
+
.withExactArgs("~oOperationMetadata~", "~ResponseEntity0~", undefined)
|
|
1739
1737
|
.returns("~oReturnValueContextFirstExecute~");
|
|
1740
1738
|
|
|
1741
1739
|
// code under test
|
|
@@ -1757,8 +1755,7 @@ sap.ui.define([
|
|
|
1757
1755
|
oBindingMock.expects("refreshDependentBindings")
|
|
1758
1756
|
.withExactArgs("", "groupId", true).returns(asyncRefresh());
|
|
1759
1757
|
oBindingMock.expects("handleOperationResult")
|
|
1760
|
-
.withExactArgs(
|
|
1761
|
-
"~oOperationMetadata~", "~ResponseEntity1~", undefined)
|
|
1758
|
+
.withExactArgs("~oOperationMetadata~", "~ResponseEntity1~", undefined)
|
|
1762
1759
|
.returns("~oReturnValueContextSecondExecute~");
|
|
1763
1760
|
|
|
1764
1761
|
// code under test
|
|
@@ -1834,8 +1831,7 @@ sap.ui.define([
|
|
|
1834
1831
|
this.mock(oBinding).expects("refreshDependentBindings").withExactArgs("", "groupId", true)
|
|
1835
1832
|
.returns(SyncPromise.resolve(Promise.resolve()));
|
|
1836
1833
|
this.mock(oBinding).expects("handleOperationResult")
|
|
1837
|
-
.withExactArgs(
|
|
1838
|
-
"~oResponseEntity~", true)
|
|
1834
|
+
.withExactArgs(oOperationMetadata, "~oResponseEntity~", true)
|
|
1839
1835
|
.returns("~oResult~");
|
|
1840
1836
|
|
|
1841
1837
|
// code under test
|
|
@@ -1875,8 +1871,7 @@ sap.ui.define([
|
|
|
1875
1871
|
this.mock(oBinding).expects("refreshDependentBindings").withExactArgs("", "groupId", true)
|
|
1876
1872
|
.returns(SyncPromise.resolve(Promise.resolve()));
|
|
1877
1873
|
this.mock(oBinding).expects("handleOperationResult")
|
|
1878
|
-
.withExactArgs("
|
|
1879
|
-
oResponseEntity, true)
|
|
1874
|
+
.withExactArgs("~oOperationMetadata~", oResponseEntity, true)
|
|
1880
1875
|
.throws(oError);
|
|
1881
1876
|
this.mock(oGroupLock).expects("unlock").withExactArgs(true);
|
|
1882
1877
|
oReportErrorExpectation = this.mock(this.oModel).expects("reportError").withExactArgs(
|
|
@@ -2080,9 +2075,85 @@ sap.ui.define([
|
|
|
2080
2075
|
});
|
|
2081
2076
|
});
|
|
2082
2077
|
|
|
2078
|
+
//*********************************************************************************************
|
|
2079
|
+
QUnit.test("getReturnValueContextPath", function (assert) {
|
|
2080
|
+
const oBinding = this.bindContext(
|
|
2081
|
+
"/EntitySet(ID='1')/navigation1/schema.Operation(...)");
|
|
2082
|
+
const oContext = {getPath : function () {}};
|
|
2083
|
+
const oContextMock = this.mock(oContext);
|
|
2084
|
+
oBinding.oContext = oContext;
|
|
2085
|
+
oBinding.oOperation.bAdditionalQueryOptionsForRVC = false;
|
|
2086
|
+
|
|
2087
|
+
oContextMock.expects("getPath").withExactArgs()
|
|
2088
|
+
.returns("/Artists('42')");
|
|
2089
|
+
const oHelperMock = this.mock(_Helper);
|
|
2090
|
+
const oResponseEntity = {};
|
|
2091
|
+
oHelperMock.expects("getPrivateAnnotation").withExactArgs(oResponseEntity, "predicate")
|
|
2092
|
+
.returns("('77')");
|
|
2093
|
+
|
|
2094
|
+
// code under test
|
|
2095
|
+
assert.strictEqual(
|
|
2096
|
+
oBinding.getReturnValueContextPath(oResponseEntity),
|
|
2097
|
+
"Artists('77')");
|
|
2098
|
+
|
|
2099
|
+
oContextMock.expects("getPath").withExactArgs()
|
|
2100
|
+
.returns("/Artists");
|
|
2101
|
+
oHelperMock.expects("getPrivateAnnotation").withExactArgs(oResponseEntity, "predicate")
|
|
2102
|
+
.returns("('77')");
|
|
2103
|
+
|
|
2104
|
+
// code under test
|
|
2105
|
+
assert.strictEqual(
|
|
2106
|
+
oBinding.getReturnValueContextPath(oResponseEntity),
|
|
2107
|
+
"Artists('77')");
|
|
2108
|
+
});
|
|
2109
|
+
|
|
2110
|
+
//*********************************************************************************************
|
|
2111
|
+
QUnit.test("getReturnValueContextPath: bAdditionalQueryOptionsForRVC = undefined",
|
|
2112
|
+
function (assert) {
|
|
2113
|
+
const oBinding = this.bindContext(
|
|
2114
|
+
"/EntitySet(ID='1')/navigation1/schema.Operation(...)");
|
|
2115
|
+
|
|
2116
|
+
oBinding.oOperation.bAdditionalQueryOptionsForRVC = undefined;
|
|
2117
|
+
|
|
2118
|
+
assert.throws(function () {
|
|
2119
|
+
// code under test
|
|
2120
|
+
oBinding.getReturnValueContextPath({/*oResponseEntity*/});
|
|
2121
|
+
}, new Error("Unexpected Value for bAdditionalQueryOptionsForRVC: undefined"));
|
|
2122
|
+
});
|
|
2123
|
+
|
|
2124
|
+
//*********************************************************************************************
|
|
2125
|
+
QUnit.test("getReturnValueContextPath with navigation property", function (assert) {
|
|
2126
|
+
const oBinding = this.bindContext(
|
|
2127
|
+
"/EntitySet(ID='1')/navigation1/schema.Operation(...)");
|
|
2128
|
+
const oContext = {getPath : function () {}};
|
|
2129
|
+
oBinding.oContext = oContext;
|
|
2130
|
+
oBinding.oOperation.bAdditionalQueryOptionsForRVC = true;
|
|
2131
|
+
this.mock(oContext).expects("getPath").withExactArgs()
|
|
2132
|
+
.returns("/Teams('42')/TEAM_2_EMPLOYEES('1')");
|
|
2133
|
+
const oResponseEntity = {"~partner~" : "~oKeyProperties~"};
|
|
2134
|
+
this.mock(_Helper).expects("getPrivateAnnotation")
|
|
2135
|
+
.withExactArgs(oResponseEntity, "predicate")
|
|
2136
|
+
.returns("('11')");
|
|
2137
|
+
this.mock(_Helper).expects("getMetaPath").withExactArgs("Teams('42')/TEAM_2_EMPLOYEES('1')")
|
|
2138
|
+
.returns("Teams/TEAM_2_EMPLOYEES");
|
|
2139
|
+
const oMetaModel = {getObject : mustBeMocked};
|
|
2140
|
+
this.mock(this.oModel).expects("getMetaModel").withExactArgs().returns(oMetaModel);
|
|
2141
|
+
this.mock(oMetaModel).expects("getObject")
|
|
2142
|
+
.withExactArgs("/Teams/TEAM_2_EMPLOYEES/$Partner")
|
|
2143
|
+
.returns("~partner~");
|
|
2144
|
+
this.mock(this.oModel).expects("getKeyPredicate")
|
|
2145
|
+
.withExactArgs("/Teams", "~oKeyProperties~")
|
|
2146
|
+
.returns("('23')");
|
|
2147
|
+
|
|
2148
|
+
// code under test
|
|
2149
|
+
assert.strictEqual(
|
|
2150
|
+
oBinding.getReturnValueContextPath(oResponseEntity),
|
|
2151
|
+
"Teams('23')/TEAM_2_EMPLOYEES('11')");
|
|
2152
|
+
});
|
|
2153
|
+
|
|
2083
2154
|
//*********************************************************************************************
|
|
2084
2155
|
QUnit.test("handleOperationResult: bound operation", function (assert) {
|
|
2085
|
-
|
|
2156
|
+
const oBinding = this.bindContext(
|
|
2086
2157
|
"/EntitySet(ID='1')/navigation1/schema.Operation(...)", null,
|
|
2087
2158
|
{$$groupId : "groupId"});
|
|
2088
2159
|
|
|
@@ -2093,7 +2164,7 @@ sap.ui.define([
|
|
|
2093
2164
|
|
|
2094
2165
|
assert.strictEqual(
|
|
2095
2166
|
// code under test
|
|
2096
|
-
oBinding.handleOperationResult(
|
|
2167
|
+
oBinding.handleOperationResult("~oOperationMetadata~"),
|
|
2097
2168
|
undefined);
|
|
2098
2169
|
});
|
|
2099
2170
|
|
|
@@ -2113,9 +2184,9 @@ sap.ui.define([
|
|
|
2113
2184
|
.withExactArgs("~oOperationMetadata~").returns(true);
|
|
2114
2185
|
this.mock(oBinding).expects("hasReturnValueContext").withExactArgs().returns(true);
|
|
2115
2186
|
this.mock(oParentContext).expects("getValue").returns(null);
|
|
2116
|
-
this.mock(
|
|
2117
|
-
.withExactArgs(
|
|
2118
|
-
.returns("
|
|
2187
|
+
this.mock(oBinding).expects("getReturnValueContextPath")
|
|
2188
|
+
.withExactArgs(oResponseEntity)
|
|
2189
|
+
.returns("TEAMS('77')");
|
|
2119
2190
|
this.mock(Context).expects("createNewContext")
|
|
2120
2191
|
.withExactArgs(sinon.match.same(this.oModel), sinon.match.same(oBinding),
|
|
2121
2192
|
"/TEAMS('77')")
|
|
@@ -2124,8 +2195,7 @@ sap.ui.define([
|
|
|
2124
2195
|
|
|
2125
2196
|
assert.strictEqual(
|
|
2126
2197
|
// code under test
|
|
2127
|
-
oBinding.handleOperationResult(
|
|
2128
|
-
"/TEAMS/name.space.Operation(...)", "~oOperationMetadata~", oResponseEntity),
|
|
2198
|
+
oBinding.handleOperationResult("~oOperationMetadata~", oResponseEntity),
|
|
2129
2199
|
"~oReturnValueContext~");
|
|
2130
2200
|
});
|
|
2131
2201
|
|
|
@@ -2142,6 +2212,7 @@ sap.ui.define([
|
|
|
2142
2212
|
oParentContext = Context.create(this.oModel, oRootBinding, "/TEAMS('42')"),
|
|
2143
2213
|
oBinding = this.bindContext("ToTwin(...)", oParentContext);
|
|
2144
2214
|
|
|
2215
|
+
oBinding.oOperation.bAdditionalQueryOptionsForRVC = false;
|
|
2145
2216
|
_Helper.setPrivateAnnotation(oParentEntity, "predicate", "('42')");
|
|
2146
2217
|
_Helper.setPrivateAnnotation(oResponseEntity, "predicate", "('77')");
|
|
2147
2218
|
this.mock(oBinding).expects("isReturnValueLikeBindingParameter")
|
|
@@ -2149,6 +2220,9 @@ sap.ui.define([
|
|
|
2149
2220
|
this.mock(oParentContext).expects("getValue").withExactArgs().returns(oParentEntity);
|
|
2150
2221
|
this.mock(oParentContext).expects("patch").never();
|
|
2151
2222
|
this.mock(oBinding).expects("hasReturnValueContext").withExactArgs().returns(true);
|
|
2223
|
+
this.mock(oBinding).expects("getReturnValueContextPath")
|
|
2224
|
+
.withExactArgs(oResponseEntity)
|
|
2225
|
+
.returns("~sReturnValueContextPath~");
|
|
2152
2226
|
this.mock(Context).expects("createNewContext").never();
|
|
2153
2227
|
this.mock(oRootBinding).expects("doReplaceWith")
|
|
2154
2228
|
.withExactArgs(sinon.match.same(oParentContext), sinon.match.same(oResponseEntity),
|
|
@@ -2158,11 +2232,70 @@ sap.ui.define([
|
|
|
2158
2232
|
|
|
2159
2233
|
assert.strictEqual(
|
|
2160
2234
|
// code under test
|
|
2161
|
-
oBinding.handleOperationResult("
|
|
2162
|
-
|
|
2235
|
+
oBinding.handleOperationResult("~oOperationMetadata~", oResponseEntity, true),
|
|
2236
|
+
oResult);
|
|
2237
|
+
});
|
|
2238
|
+
|
|
2239
|
+
//*********************************************************************************************
|
|
2240
|
+
QUnit.test("handleOperationResult: bReplaceWithRVC and navigation property", function (assert) {
|
|
2241
|
+
const oRootBinding = {doReplaceWith : mustBeMocked};
|
|
2242
|
+
const oParentContext = Context.create(this.oModel, oRootBinding,
|
|
2243
|
+
"/TEAMS('42')/TEAM_2_EMPLOYEES(1)");
|
|
2244
|
+
const oBinding = this.bindContext("ToTwin(...)", oParentContext);
|
|
2245
|
+
oBinding.oOperation.bAdditionalQueryOptionsForRVC = true;
|
|
2246
|
+
const oParentEntity = {};
|
|
2247
|
+
_Helper.setPrivateAnnotation(oParentEntity, "predicate", "('1')");
|
|
2248
|
+
const oResponseEntity = {};
|
|
2249
|
+
_Helper.setPrivateAnnotation(oResponseEntity, "predicate", "('11')");
|
|
2250
|
+
this.mock(oBinding).expects("isReturnValueLikeBindingParameter")
|
|
2251
|
+
.withExactArgs("~oOperationMetadata~").returns(true);
|
|
2252
|
+
this.mock(oParentContext).expects("getValue").withExactArgs().returns(oParentEntity);
|
|
2253
|
+
this.mock(oParentContext).expects("patch").never();
|
|
2254
|
+
this.mock(oBinding).expects("hasReturnValueContext").withExactArgs().returns(true);
|
|
2255
|
+
this.mock(oBinding).expects("getReturnValueContextPath")
|
|
2256
|
+
.withExactArgs(oResponseEntity)
|
|
2257
|
+
.returns("/TEAMS('42')/TEAM_2_EMPLOYEES('11')");
|
|
2258
|
+
this.mock(Context).expects("createNewContext").never();
|
|
2259
|
+
const oResult = {setNewGeneration : mustBeMocked};
|
|
2260
|
+
this.mock(oRootBinding).expects("doReplaceWith")
|
|
2261
|
+
.withExactArgs(sinon.match.same(oParentContext), sinon.match.same(oResponseEntity),
|
|
2262
|
+
"('11')")
|
|
2263
|
+
.returns(oResult);
|
|
2264
|
+
this.mock(oResult).expects("setNewGeneration").withExactArgs();
|
|
2265
|
+
|
|
2266
|
+
assert.strictEqual(
|
|
2267
|
+
// code under test
|
|
2268
|
+
oBinding.handleOperationResult("~oOperationMetadata~", oResponseEntity, true),
|
|
2163
2269
|
oResult);
|
|
2164
2270
|
});
|
|
2165
2271
|
|
|
2272
|
+
//*********************************************************************************************
|
|
2273
|
+
QUnit.test("handleOperationResult: bReplaceWithRVC = true and keypredicate has changed",
|
|
2274
|
+
function (assert) {
|
|
2275
|
+
const oRootBinding = {};
|
|
2276
|
+
const oParentContext = Context.create(this.oModel, oRootBinding,
|
|
2277
|
+
"/TEAMS('42')/TEAM_2_EMPLOYEES(1)");
|
|
2278
|
+
const oBinding = this.bindContext("ToTwin(...)", oParentContext);
|
|
2279
|
+
oBinding.oOperation.bAdditionalQueryOptionsForRVC = true;
|
|
2280
|
+
const oParentEntity = {};
|
|
2281
|
+
_Helper.setPrivateAnnotation(oParentEntity, "predicate", "('1')");
|
|
2282
|
+
const oResponseEntity = {};
|
|
2283
|
+
_Helper.setPrivateAnnotation(oResponseEntity, "predicate", ("11"));
|
|
2284
|
+
this.mock(oBinding).expects("isReturnValueLikeBindingParameter")
|
|
2285
|
+
.withExactArgs("~oOperationMetadata~").returns(true);
|
|
2286
|
+
this.mock(oParentContext).expects("getValue").withExactArgs().returns(oParentEntity);
|
|
2287
|
+
this.mock(oParentContext).expects("patch").never();
|
|
2288
|
+
this.mock(oBinding).expects("hasReturnValueContext").withExactArgs().returns(true);
|
|
2289
|
+
this.mock(oBinding).expects("getReturnValueContextPath")
|
|
2290
|
+
.withExactArgs(oResponseEntity)
|
|
2291
|
+
.returns("/TEAMS('77')/TEAM_2_EMPLOYEES('11')");
|
|
2292
|
+
|
|
2293
|
+
assert.throws(function () {
|
|
2294
|
+
// code under test
|
|
2295
|
+
oBinding.handleOperationResult("~oOperationMetadata~", oResponseEntity, true);
|
|
2296
|
+
}, new Error("Cannot replace due changed key predicates and navigation property in path"));
|
|
2297
|
+
});
|
|
2298
|
+
|
|
2166
2299
|
//*********************************************************************************************
|
|
2167
2300
|
QUnit.test("handleOperationResult: bReplaceWithRVC w/o r.v.c.", function (assert) {
|
|
2168
2301
|
var oParentContext = Context.create(this.oModel, {/*oRootBinding*/}, "/TEAMS('42')"),
|
|
@@ -2180,8 +2313,7 @@ sap.ui.define([
|
|
|
2180
2313
|
|
|
2181
2314
|
assert.throws(function () {
|
|
2182
2315
|
// code under test
|
|
2183
|
-
oBinding.handleOperationResult("
|
|
2184
|
-
"~oOperationMetadata~", oResponseEntity, true);
|
|
2316
|
+
oBinding.handleOperationResult("~oOperationMetadata~", oResponseEntity, true);
|
|
2185
2317
|
}, new Error("Cannot replace w/o return value context"));
|
|
2186
2318
|
});
|
|
2187
2319
|
|
|
@@ -2206,14 +2338,14 @@ sap.ui.define([
|
|
|
2206
2338
|
if (bReplaceWithRVC) {
|
|
2207
2339
|
assert.throws(function () {
|
|
2208
2340
|
// code under test
|
|
2209
|
-
oBinding.handleOperationResult("
|
|
2210
|
-
|
|
2341
|
+
oBinding.handleOperationResult("~oOperationMetadata~", {/*oResponseEntity*/},
|
|
2342
|
+
bReplaceWithRVC);
|
|
2211
2343
|
}, new Error("Cannot replace w/o return value context"));
|
|
2212
2344
|
} else {
|
|
2213
2345
|
assert.strictEqual(
|
|
2214
2346
|
// code under test
|
|
2215
|
-
oBinding.handleOperationResult("
|
|
2216
|
-
|
|
2347
|
+
oBinding.handleOperationResult("~oOperationMetadata~", {/*oResponseEntity*/},
|
|
2348
|
+
bReplaceWithRVC),
|
|
2217
2349
|
undefined);
|
|
2218
2350
|
}
|
|
2219
2351
|
});
|
|
@@ -2254,9 +2386,9 @@ sap.ui.define([
|
|
|
2254
2386
|
this.mock(oParentContext).expects("patch")
|
|
2255
2387
|
.exactly(oFixture.bRead && oFixture.sId === "42" ? 1 : 0)
|
|
2256
2388
|
.withExactArgs(sinon.match.same(oResponseEntity));
|
|
2257
|
-
this.mock(
|
|
2258
|
-
.withExactArgs(
|
|
2259
|
-
.returns("
|
|
2389
|
+
this.mock(oBinding).expects("getReturnValueContextPath")
|
|
2390
|
+
.withExactArgs(sinon.match.same(oResponseEntity))
|
|
2391
|
+
.returns("TEAMS" + sPredicate);
|
|
2260
2392
|
this.mock(Context).expects("createNewContext")
|
|
2261
2393
|
.withExactArgs(this.oModel, oBinding, "/TEAMS" + sPredicate)
|
|
2262
2394
|
.returns("~oReturnValueContext~");
|
|
@@ -2265,8 +2397,7 @@ sap.ui.define([
|
|
|
2265
2397
|
|
|
2266
2398
|
assert.strictEqual(
|
|
2267
2399
|
// code under test
|
|
2268
|
-
oBinding.handleOperationResult("
|
|
2269
|
-
"~oOperationMetadata~", oResponseEntity),
|
|
2400
|
+
oBinding.handleOperationResult("~oOperationMetadata~", oResponseEntity),
|
|
2270
2401
|
"~oReturnValueContext~");
|
|
2271
2402
|
});
|
|
2272
2403
|
});
|
|
@@ -2295,9 +2426,7 @@ sap.ui.define([
|
|
|
2295
2426
|
|
|
2296
2427
|
assert.strictEqual(
|
|
2297
2428
|
// code under test
|
|
2298
|
-
oBinding.handleOperationResult(
|
|
2299
|
-
"/TEAMS('42')/TEAM_2_MANAGER/name.space.Operation(...)", "~oOperationMetadata~",
|
|
2300
|
-
oResponseEntity),
|
|
2429
|
+
oBinding.handleOperationResult("~oOperationMetadata~", oResponseEntity),
|
|
2301
2430
|
undefined);
|
|
2302
2431
|
});
|
|
2303
2432
|
});
|
|
@@ -2325,6 +2454,9 @@ sap.ui.define([
|
|
|
2325
2454
|
.returns(mParametersCopy);
|
|
2326
2455
|
this.mock(oBinding).expects("computeOperationQueryOptions").withExactArgs()
|
|
2327
2456
|
.returns(mQueryOptions);
|
|
2457
|
+
this.mock(oBinding).expects("addQueryOptionsForReturnValueContext")
|
|
2458
|
+
.withExactArgs(oOperationMetadata, mQueryOptions)
|
|
2459
|
+
.returns(mQueryOptions);
|
|
2328
2460
|
this.mock(this.oModel.oRequestor).expects("getPathAndAddQueryOptions")
|
|
2329
2461
|
.withExactArgs(sPath, sinon.match.same(oOperationMetadata),
|
|
2330
2462
|
sinon.match.same(mParametersCopy), sinon.match.same(mQueryOptions), undefined)
|
|
@@ -2377,6 +2509,9 @@ sap.ui.define([
|
|
|
2377
2509
|
.returns(mParametersCopy);
|
|
2378
2510
|
this.mock(oBinding).expects("computeOperationQueryOptions").withExactArgs()
|
|
2379
2511
|
.returns(mQueryOptions);
|
|
2512
|
+
this.mock(oBinding).expects("addQueryOptionsForReturnValueContext")
|
|
2513
|
+
.withExactArgs(oOperationMetadata, mQueryOptions)
|
|
2514
|
+
.returns(mQueryOptions);
|
|
2380
2515
|
this.mock(this.oModel.oRequestor).expects("getPathAndAddQueryOptions").withExactArgs(sPath,
|
|
2381
2516
|
sinon.match.same(oOperationMetadata), sinon.match.same(mParametersCopy),
|
|
2382
2517
|
sinon.match.same(mQueryOptions), sinon.match.same(fnGetEntity))
|
|
@@ -2421,6 +2556,7 @@ sap.ui.define([
|
|
|
2421
2556
|
this.mock(_Cache).expects("createSingle").never();
|
|
2422
2557
|
assert.deepEqual(oBinding.oOperation, {
|
|
2423
2558
|
bAction : undefined,
|
|
2559
|
+
bAdditionalQueryOptionsForRVC : undefined,
|
|
2424
2560
|
mChangeListeners : {},
|
|
2425
2561
|
mParameters : {},
|
|
2426
2562
|
mRefreshParameters : {}
|
|
@@ -2434,6 +2570,7 @@ sap.ui.define([
|
|
|
2434
2570
|
|
|
2435
2571
|
assert.deepEqual(oBinding.oOperation, {
|
|
2436
2572
|
bAction : undefined,
|
|
2573
|
+
bAdditionalQueryOptionsForRVC : undefined,
|
|
2437
2574
|
mChangeListeners : {},
|
|
2438
2575
|
mParameters : {},
|
|
2439
2576
|
mRefreshParameters : {}
|
|
@@ -2458,6 +2595,9 @@ sap.ui.define([
|
|
|
2458
2595
|
this.mock(Object).expects("assign").withExactArgs({}, {}).returns("~mParametersCopy~");
|
|
2459
2596
|
this.mock(oBinding).expects("computeOperationQueryOptions").withExactArgs()
|
|
2460
2597
|
.returns("~mQueryOptions~");
|
|
2598
|
+
this.mock(oBinding).expects("addQueryOptionsForReturnValueContext")
|
|
2599
|
+
.withExactArgs(oOperationMetadata, "~mQueryOptions~")
|
|
2600
|
+
.returns("~mQueryOptions~");
|
|
2461
2601
|
this.mock(this.oModel.oRequestor).expects("getPathAndAddQueryOptions")
|
|
2462
2602
|
.withExactArgs(sPath, sinon.match.same(oOperationMetadata), "~mParametersCopy~",
|
|
2463
2603
|
"~mQueryOptions~", "~fnGetEntity~")
|
|
@@ -2484,8 +2624,8 @@ sap.ui.define([
|
|
|
2484
2624
|
assert.deepEqual(oBinding.oOperation.mRefreshParameters, {/*mParameters*/});
|
|
2485
2625
|
|
|
2486
2626
|
this.mock(oBinding).expects("hasReturnValueContext").withExactArgs().returns(true);
|
|
2487
|
-
this.mock(
|
|
2488
|
-
.withExactArgs(
|
|
2627
|
+
this.mock(oBinding).expects("getReturnValueContextPath")
|
|
2628
|
+
.withExactArgs(sinon.match.same(oResponseEntity))
|
|
2489
2629
|
.returns("Entity('2')");
|
|
2490
2630
|
|
|
2491
2631
|
// code under test
|
|
@@ -2515,6 +2655,9 @@ sap.ui.define([
|
|
|
2515
2655
|
.returns(mParametersCopy);
|
|
2516
2656
|
this.mock(oBinding).expects("computeOperationQueryOptions").withExactArgs()
|
|
2517
2657
|
.returns(mQueryOptions);
|
|
2658
|
+
this.mock(oBinding).expects("addQueryOptionsForReturnValueContext")
|
|
2659
|
+
.withExactArgs(oOperationMetadata, mQueryOptions)
|
|
2660
|
+
.returns(mQueryOptions);
|
|
2518
2661
|
this.mock(this.oModel.oRequestor).expects("getPathAndAddQueryOptions").withExactArgs(sPath,
|
|
2519
2662
|
sinon.match.same(oOperationMetadata), sinon.match.same(mParametersCopy),
|
|
2520
2663
|
sinon.match.same(mQueryOptions), undefined)
|
|
@@ -2584,6 +2727,9 @@ sap.ui.define([
|
|
|
2584
2727
|
.returns(mParametersCopy);
|
|
2585
2728
|
this.mock(oBinding).expects("computeOperationQueryOptions").withExactArgs()
|
|
2586
2729
|
.returns(mQueryOptions);
|
|
2730
|
+
this.mock(oBinding).expects("addQueryOptionsForReturnValueContext")
|
|
2731
|
+
.withExactArgs(oOperationMetadata, mQueryOptions)
|
|
2732
|
+
.returns(mQueryOptions);
|
|
2587
2733
|
this.mock(this.oModel.oRequestor).expects("getPathAndAddQueryOptions")
|
|
2588
2734
|
.withExactArgs(sPath, sinon.match.same(oOperationMetadata),
|
|
2589
2735
|
sinon.match.same(mParametersCopy), sinon.match.same(mQueryOptions),
|
|
@@ -2621,11 +2767,8 @@ sap.ui.define([
|
|
|
2621
2767
|
.returns(true);
|
|
2622
2768
|
this.mock(oBinding).expects("hasReturnValueContext").withExactArgs()
|
|
2623
2769
|
.returns(true);
|
|
2624
|
-
|
|
2625
|
-
.withExactArgs(sinon.match.same(oResponseEntity)
|
|
2626
|
-
.returns("('42')");
|
|
2627
|
-
oHelperMock.expects("getReturnValueContextPath")
|
|
2628
|
-
.withExactArgs("Entity('1')/navigation/bound.Action(...)", "('42')")
|
|
2770
|
+
this.mock(oBinding).expects("getReturnValueContextPath")
|
|
2771
|
+
.withExactArgs(sinon.match.same(oResponseEntity))
|
|
2629
2772
|
.returns("Entity('42')");
|
|
2630
2773
|
|
|
2631
2774
|
// code under test ("getOriginalResourcePath")
|
|
@@ -2711,6 +2854,9 @@ sap.ui.define([
|
|
|
2711
2854
|
.returns(mParametersCopy);
|
|
2712
2855
|
this.mock(oBinding).expects("computeOperationQueryOptions").withExactArgs()
|
|
2713
2856
|
.returns(mExpectedQueryOptions);
|
|
2857
|
+
this.mock(oBinding).expects("addQueryOptionsForReturnValueContext")
|
|
2858
|
+
.withExactArgs(oOperationMetadata, mExpectedQueryOptions)
|
|
2859
|
+
.returns(mExpectedQueryOptions);
|
|
2714
2860
|
this.mock(this.oModel.oRequestor).expects("getPathAndAddQueryOptions")
|
|
2715
2861
|
.withExactArgs(sPath, sinon.match.same(oOperationMetadata),
|
|
2716
2862
|
sinon.match.same(mParametersCopy), sinon.match.same(mExpectedQueryOptions),
|
|
@@ -4209,9 +4355,20 @@ sap.ui.define([
|
|
|
4209
4355
|
$kind : "EntitySet",
|
|
4210
4356
|
result : true
|
|
4211
4357
|
}, { // operation binding's context must not address entity via navigation property
|
|
4358
|
+
additionalQueryOptionsForRVC : false,
|
|
4212
4359
|
binding : "name.space.Operation(...)",
|
|
4213
4360
|
context : "/TEAMS('42')/TEAM_2_MANAGER",
|
|
4214
4361
|
result : false
|
|
4362
|
+
}, { // operation binding's context must address entity via navigation property
|
|
4363
|
+
additionalQueryOptionsForRVC : true,
|
|
4364
|
+
binding : "name.space.Operation(...)",
|
|
4365
|
+
context : "/TEAMS('42')/TEAM_2_MANAGER",
|
|
4366
|
+
result : true
|
|
4367
|
+
}, { // operation binding's context could address entity via navigation property
|
|
4368
|
+
additionalQueryOptionsForRVC : undefined,
|
|
4369
|
+
binding : "name.space.Operation(...)",
|
|
4370
|
+
context : "/TEAMS('42')/TEAM_2_MANAGER",
|
|
4371
|
+
result : true
|
|
4215
4372
|
}, { // operation binding's context must not address a function import's return value
|
|
4216
4373
|
binding : "name.space.Operation(...)",
|
|
4217
4374
|
context : "/FunctionImport()",
|
|
@@ -4223,6 +4380,8 @@ sap.ui.define([
|
|
|
4223
4380
|
var oContext = oFixture.context && Context.create(this.oModel, {}, oFixture.context),
|
|
4224
4381
|
oBinding = this.bindContext(oFixture.binding, oContext);
|
|
4225
4382
|
|
|
4383
|
+
oBinding.oOperation.bAdditionalQueryOptionsForRVC
|
|
4384
|
+
= oFixture.additionalQueryOptionsForRVC;
|
|
4226
4385
|
this.mock(oBinding).expects("isReturnValueLikeBindingParameter").never();
|
|
4227
4386
|
if (oFixture.contextMetaPath) {
|
|
4228
4387
|
this.mock(this.oModel.oMetaModel).expects("getObject")
|
|
@@ -4808,6 +4967,143 @@ sap.ui.define([
|
|
|
4808
4967
|
assert.strictEqual(oBinding.getDependentBindings(), aDependentBindings);
|
|
4809
4968
|
});
|
|
4810
4969
|
|
|
4970
|
+
//*********************************************************************************************
|
|
4971
|
+
[{
|
|
4972
|
+
bHasInitialSelect : true
|
|
4973
|
+
}, {
|
|
4974
|
+
bHasInitialSelect : false
|
|
4975
|
+
}].forEach(function (oFixture) {
|
|
4976
|
+
var sTitle = "addQueryOptionsForReturnValueContext: bHasInitialSelect = "
|
|
4977
|
+
+ oFixture.bHasInitialSelect;
|
|
4978
|
+
|
|
4979
|
+
QUnit.test(sTitle, function (assert) {
|
|
4980
|
+
const oBinding = this.bindContext("/Operation(...)");
|
|
4981
|
+
const oMetaModel = {getObject : mustBeMocked};
|
|
4982
|
+
const oMetaModelMock = this.mock(oMetaModel);
|
|
4983
|
+
this.mock(oBinding.oModel).expects("getMetaModel").returns(oMetaModel);
|
|
4984
|
+
this.mock(oBinding).expects("getResolvedPath").returns("~resolvedPath~");
|
|
4985
|
+
const oHelperMock = this.mock(_Helper);
|
|
4986
|
+
oHelperMock.expects("getMetaPath").withExactArgs("~resolvedPath~").returns("/a/b/c");
|
|
4987
|
+
this.mock(oBinding).expects("isReturnValueLikeBindingParameter")
|
|
4988
|
+
.withExactArgs("~oOperationMetaData")
|
|
4989
|
+
.returns(true);
|
|
4990
|
+
this.mock(oBinding).expects("hasReturnValueContext")
|
|
4991
|
+
.withExactArgs()
|
|
4992
|
+
.returns(true);
|
|
4993
|
+
oMetaModelMock.expects("getObject")
|
|
4994
|
+
.withExactArgs("/a/$NavigationPropertyBinding/b")
|
|
4995
|
+
.returns("~EntitySet~");
|
|
4996
|
+
oMetaModelMock.expects("getObject")
|
|
4997
|
+
.withExactArgs("/a/b/$Partner")
|
|
4998
|
+
.returns("~Partner~");
|
|
4999
|
+
oMetaModelMock.expects("getObject").withExactArgs("/~EntitySet~/~Partner~/")
|
|
5000
|
+
.returns("~SelectForPartner~");
|
|
5001
|
+
const mAdditionalQueryOptions = {$expand : {"~Partner~" : {}}};
|
|
5002
|
+
oHelperMock.expects("selectKeyProperties")
|
|
5003
|
+
.withExactArgs(mAdditionalQueryOptions.$expand["~Partner~"], "~SelectForPartner~");
|
|
5004
|
+
oMetaModelMock.expects("getObject")
|
|
5005
|
+
.exactly(oFixture.bHasInitialSelect ? 1 : 0)
|
|
5006
|
+
.withExactArgs("/~EntitySet~/")
|
|
5007
|
+
.returns("~SelectForEntitySet~");
|
|
5008
|
+
oHelperMock.expects("selectKeyProperties")
|
|
5009
|
+
.exactly(oFixture.bHasInitialSelect ? 1 : 0)
|
|
5010
|
+
.withExactArgs(mAdditionalQueryOptions, "~SelectForEntitySet~");
|
|
5011
|
+
const mQueryOptions = oFixture.bHasInitialSelect ? {$select : ["~select~"]} : {};
|
|
5012
|
+
oHelperMock.expects("clone").withExactArgs(mQueryOptions).returns("~clonedQueryOptions~");
|
|
5013
|
+
oHelperMock.expects("aggregateExpandSelect")
|
|
5014
|
+
.withExactArgs("~clonedQueryOptions~", mAdditionalQueryOptions);
|
|
5015
|
+
|
|
5016
|
+
// code under test
|
|
5017
|
+
assert.strictEqual(
|
|
5018
|
+
oBinding.addQueryOptionsForReturnValueContext("~oOperationMetaData", mQueryOptions),
|
|
5019
|
+
"~clonedQueryOptions~");
|
|
5020
|
+
|
|
5021
|
+
assert.strictEqual(
|
|
5022
|
+
oBinding.oOperation.bAdditionalQueryOptionsForRVC, true);
|
|
5023
|
+
});
|
|
5024
|
+
});
|
|
5025
|
+
|
|
5026
|
+
//*********************************************************************************************
|
|
5027
|
+
[{
|
|
5028
|
+
bHasPartner : true,
|
|
5029
|
+
bHasEntitySet : false
|
|
5030
|
+
}, {
|
|
5031
|
+
bHasPartner : false,
|
|
5032
|
+
bHasEntitySet : true
|
|
5033
|
+
}].forEach(function (oFixture) {
|
|
5034
|
+
var sTitle = "addQueryOptionsForReturnValueContext: bHasPartner = "
|
|
5035
|
+
+ oFixture.bHasPartner + " && bHasEntitySet = " + oFixture.bHasEntitySet;
|
|
5036
|
+
|
|
5037
|
+
QUnit.test(sTitle, function (assert) {
|
|
5038
|
+
const oBinding = this.bindContext("/Operation(...)");
|
|
5039
|
+
const oMetaModel = {getObject : mustBeMocked};
|
|
5040
|
+
this.mock(oBinding.oModel).expects("getMetaModel").returns(oMetaModel);
|
|
5041
|
+
this.mock(oBinding).expects("getResolvedPath").returns("~resolvedPath~");
|
|
5042
|
+
this.mock(_Helper).expects("getMetaPath").withExactArgs("~resolvedPath~").returns("/a/b/c");
|
|
5043
|
+
this.mock(oBinding).expects("isReturnValueLikeBindingParameter")
|
|
5044
|
+
.withExactArgs("~oOperationMetaData")
|
|
5045
|
+
.returns(true);
|
|
5046
|
+
this.mock(oBinding).expects("hasReturnValueContext")
|
|
5047
|
+
.withExactArgs()
|
|
5048
|
+
.returns(true);
|
|
5049
|
+
const oMetaModelMock = this.mock(oMetaModel);
|
|
5050
|
+
oMetaModelMock.expects("getObject")
|
|
5051
|
+
.withExactArgs("/a/$NavigationPropertyBinding/b")
|
|
5052
|
+
.returns(oFixture.bHasEntitySet ? "~EntitySet~" : undefined);
|
|
5053
|
+
oMetaModelMock.expects("getObject")
|
|
5054
|
+
.withExactArgs("/a/b/$Partner")
|
|
5055
|
+
.returns(oFixture.bHasPartner ? "~Partner~" : undefined);
|
|
5056
|
+
|
|
5057
|
+
// code under test
|
|
5058
|
+
assert.strictEqual(
|
|
5059
|
+
oBinding.addQueryOptionsForReturnValueContext("~oOperationMetaData", "~mQueryOptions~"),
|
|
5060
|
+
"~mQueryOptions~");
|
|
5061
|
+
|
|
5062
|
+
assert.strictEqual(
|
|
5063
|
+
oBinding.oOperation.bAdditionalQueryOptionsForRVC, false);
|
|
5064
|
+
});
|
|
5065
|
+
});
|
|
5066
|
+
|
|
5067
|
+
//*********************************************************************************************
|
|
5068
|
+
[{
|
|
5069
|
+
bIsReturnValueLikeBindingParameter : false,
|
|
5070
|
+
sMetaPath : "/a/b/c"
|
|
5071
|
+
}, {
|
|
5072
|
+
bIsReturnValueLikeBindingParameter : true,
|
|
5073
|
+
bHasReturnValueContext : false,
|
|
5074
|
+
sMetaPath : "/a/b/c"
|
|
5075
|
+
}, {
|
|
5076
|
+
bIsReturnValueLikeBindingParameter : true,
|
|
5077
|
+
bHasReturnValueContext : true,
|
|
5078
|
+
sMetaPath : "/a/b"
|
|
5079
|
+
}].forEach(function (oFixture) {
|
|
5080
|
+
var sTitle = "addQueryOptionsForReturnValueContext: " + JSON.stringify(oFixture);
|
|
5081
|
+
|
|
5082
|
+
QUnit.test(sTitle, function (assert) {
|
|
5083
|
+
const oBinding = this.bindContext("/Operation(...)");
|
|
5084
|
+
this.mock(oBinding).expects("getResolvedPath").returns("~resolvedPath~");
|
|
5085
|
+
this.mock(_Helper).expects("getMetaPath").withExactArgs("~resolvedPath~")
|
|
5086
|
+
.returns(oFixture.sMetaPath);
|
|
5087
|
+
const oOperationsMetadata = {};
|
|
5088
|
+
this.mock(oBinding).expects("isReturnValueLikeBindingParameter")
|
|
5089
|
+
.withExactArgs(sinon.match.same(oOperationsMetadata))
|
|
5090
|
+
.returns(oFixture.bIsReturnValueLikeBindingParameter);
|
|
5091
|
+
this.mock(oBinding).expects("hasReturnValueContext")
|
|
5092
|
+
.exactly(oFixture.bIsReturnValueLikeBindingParameter ? 1 : 0)
|
|
5093
|
+
.withExactArgs()
|
|
5094
|
+
.returns(oFixture.bHasReturnValueContext);
|
|
5095
|
+
|
|
5096
|
+
const mQueryOptions = {};
|
|
5097
|
+
// code under test
|
|
5098
|
+
assert.strictEqual(
|
|
5099
|
+
oBinding.addQueryOptionsForReturnValueContext(oOperationsMetadata, mQueryOptions),
|
|
5100
|
+
mQueryOptions);
|
|
5101
|
+
|
|
5102
|
+
assert.strictEqual(
|
|
5103
|
+
oBinding.oOperation.bAdditionalQueryOptionsForRVC, false);
|
|
5104
|
+
});
|
|
5105
|
+
});
|
|
5106
|
+
|
|
4811
5107
|
//*********************************************************************************************
|
|
4812
5108
|
[
|
|
4813
5109
|
Context.create({/*oModel*/}, {/*oBinding*/}, "/SalesOrderList($uid=1)"),
|
|
@@ -4859,50 +5155,34 @@ sap.ui.define([
|
|
|
4859
5155
|
|
|
4860
5156
|
//*********************************************************************************************
|
|
4861
5157
|
QUnit.test("doDeregisterChangeListener: super", function () {
|
|
4862
|
-
|
|
4863
|
-
oListener = {},
|
|
4864
|
-
sPath = "foo";
|
|
5158
|
+
const oBinding = this.bindContext("/EMPLOYEES('42')");
|
|
4865
5159
|
|
|
4866
5160
|
this.mock(asODataParentBinding.prototype).expects("doDeregisterChangeListener")
|
|
4867
|
-
.on(oBinding).withExactArgs(
|
|
5161
|
+
.on(oBinding).withExactArgs("/absolute/path", "~oListener~");
|
|
4868
5162
|
|
|
4869
5163
|
// code under test
|
|
4870
|
-
oBinding.doDeregisterChangeListener(
|
|
5164
|
+
oBinding.doDeregisterChangeListener("/absolute/path", "~oListener~");
|
|
4871
5165
|
});
|
|
4872
5166
|
|
|
4873
5167
|
//*********************************************************************************************
|
|
4874
|
-
|
|
4875
|
-
|
|
4876
|
-
|
|
4877
|
-
oListener = {};
|
|
5168
|
+
[undefined, "", "relative/path"].forEach(function (sRelativePath, i) {
|
|
5169
|
+
QUnit.test(`doDeregisterChangeListener: operation binding, ${sRelativePath}`, function () {
|
|
5170
|
+
const oBinding = this.bindContext("/Operation(...)");
|
|
4878
5171
|
|
|
5172
|
+
this.mock(_Helper).expects("getRelativePath")
|
|
5173
|
+
.withExactArgs("/absolute/path", "/Operation(...)/$Parameter")
|
|
5174
|
+
.returns(sRelativePath);
|
|
5175
|
+
this.mock(_Helper).expects("removeByPath").exactly(i ? 1 : 0)
|
|
5176
|
+
.withExactArgs(sinon.match.same(oBinding.oOperation.mChangeListeners), sRelativePath,
|
|
5177
|
+
"~oListener~");
|
|
4879
5178
|
this.mock(asODataParentBinding.prototype).expects("doDeregisterChangeListener")
|
|
4880
|
-
.
|
|
5179
|
+
.exactly(i ? 0 : 1)
|
|
5180
|
+
.on(oBinding).withExactArgs("/absolute/path", sinon.match.same("~oListener~"));
|
|
4881
5181
|
|
|
4882
5182
|
// code under test
|
|
4883
|
-
oBinding.doDeregisterChangeListener("
|
|
4884
|
-
|
|
4885
|
-
oHelperMock.expects("removeByPath")
|
|
4886
|
-
.withExactArgs(sinon.match.same(oBinding.oOperation.mChangeListeners), "bar",
|
|
4887
|
-
sinon.match.same(oListener));
|
|
4888
|
-
|
|
4889
|
-
// code under test
|
|
4890
|
-
oBinding.doDeregisterChangeListener("$Parameter/bar", oListener);
|
|
4891
|
-
|
|
4892
|
-
oHelperMock.expects("removeByPath")
|
|
4893
|
-
.withExactArgs(sinon.match.same(oBinding.oOperation.mChangeListeners), "bar/foo",
|
|
4894
|
-
sinon.match.same(oListener));
|
|
4895
|
-
|
|
4896
|
-
// code under test
|
|
4897
|
-
oBinding.doDeregisterChangeListener("$Parameter/bar/foo", oListener);
|
|
4898
|
-
|
|
4899
|
-
oHelperMock.expects("removeByPath")
|
|
4900
|
-
.withExactArgs(sinon.match.same(oBinding.oOperation.mChangeListeners), "",
|
|
4901
|
-
sinon.match.same(oListener));
|
|
4902
|
-
|
|
4903
|
-
// code under test
|
|
4904
|
-
oBinding.doDeregisterChangeListener("$Parameter", oListener);
|
|
5183
|
+
oBinding.doDeregisterChangeListener("/absolute/path", "~oListener~");
|
|
4905
5184
|
});
|
|
5185
|
+
});
|
|
4906
5186
|
|
|
4907
5187
|
//*********************************************************************************************
|
|
4908
5188
|
QUnit.test("doSetProperty: non operational binding", function (assert) {
|