diff --git a/src/XrmMockupShared/Core.cs b/src/XrmMockupShared/Core.cs index 452339d4..324bb56a 100644 --- a/src/XrmMockupShared/Core.cs +++ b/src/XrmMockupShared/Core.cs @@ -197,6 +197,7 @@ private void InitializeDB() new RetrieveAttributeRequestHandler(this, db, metadata, security), new WhoAmIRequestHandler(this, db, metadata, security), new RetrievePrincipalAccessRequestHandler(this, db, metadata, security), + new RetrieveMetadataChangesRequestHandler(this, db, metadata, security) }; internal void EnableProxyTypes(Assembly assembly) diff --git a/src/XrmMockupShared/XrmMockupShared.projitems b/src/XrmMockupShared/XrmMockupShared.projitems index a555274b..d3c337fc 100644 --- a/src/XrmMockupShared/XrmMockupShared.projitems +++ b/src/XrmMockupShared/XrmMockupShared.projitems @@ -23,6 +23,7 @@ + diff --git a/tests/SharedTests/TestMetadata.cs b/tests/SharedTests/TestMetadata.cs index 412661cf..381466f8 100644 --- a/tests/SharedTests/TestMetadata.cs +++ b/tests/SharedTests/TestMetadata.cs @@ -7,6 +7,7 @@ using Xunit; using System.Linq; using Xunit.Sdk; +using Microsoft.Xrm.Sdk.Metadata.Query; namespace DG.XrmMockupTest { @@ -208,6 +209,28 @@ public void RetrieveDefaultFilteredEntityMetadata() Assert.Null(resp.EntityMetadata.Attributes); } + [Fact] + public void RetrieveMetadataChangesRequest() + { + var entityFilter = new MetadataFilterExpression(LogicalOperator.And); + entityFilter.Conditions.Add(new MetadataConditionExpression("ObjectTypeCode ", MetadataConditionOperator.Equals, 1)); + var propertyExpression = new MetadataPropertiesExpression { AllProperties = false }; + propertyExpression.PropertyNames.Add("LogicalName"); + var entityQueryExpression = new EntityQueryExpression() + { + Criteria = entityFilter, + Properties = propertyExpression + }; + + var retrieveMetadataChangesRequest = new RetrieveMetadataChangesRequest() + { + Query = entityQueryExpression + }; + + var response = (RetrieveMetadataChangesResponse)orgAdminService.Execute(retrieveMetadataChangesRequest); + + Assert.Equal("account", response.EntityMetadata[0].LogicalName); + } } }